// Copyright (C) 2016 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 #include "testcodeinjection.h" #include "testutil.h" #include #include #include #include #include #include #include #include #include using namespace Qt::StringLiterals; void TestCodeInjections::testReadFile_data() { QTest::addColumn("filePath"); QTest::addColumn("snippet"); QTest::addColumn("expected"); QTest::newRow("utf8") << QString::fromLatin1(":/utf8code.txt") << QString() << QString::fromUtf8("\xC3\xA1\xC3\xA9\xC3\xAD\xC3\xB3\xC3\xBA"); QTest::newRow("snippet") << QString::fromLatin1(":/injectedcode.txt") << QString::fromLatin1("label") << QString::fromLatin1("code line"); } void TestCodeInjections::testReadFile() { QFETCH(QString, filePath); QFETCH(QString, snippet); QFETCH(QString, expected); const char* cppCode ="struct A {};\n"; int argc = 0; char *argv[] = {nullptr}; QCoreApplication app(argc, argv); QString attribute = u"file='"_s + filePath + u'\''; if (!snippet.isEmpty()) attribute += u" snippet='"_s + snippet + u'\''; QString xmlCode = u"\ \n\ \n\ \n\ \n\ \n\ \n\ \n"_s; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode.toLocal8Bit().constData())); QVERIFY(!builder.isNull()); AbstractMetaClassList classes = builder->classes(); const AbstractMetaClass *classA = AbstractMetaClass::findClass(classes, u"A"); QCOMPARE(classA->typeEntry()->codeSnips().size(), 1); QString code = classA->typeEntry()->codeSnips().constFirst().code(); QVERIFY(code.indexOf(expected) != -1); code = classA->typeEntry()->targetConversionRule(); QVERIFY(code.indexOf(expected) != -1); } void TestCodeInjections::testInjectWithValidApiVersion() { const char* cppCode ="struct A {};\n"; const char* xmlCode = "\ \n\ \n\ \n\ test Inject code\n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, true, u"1.0"_s)); QVERIFY(!builder.isNull()); AbstractMetaClassList classes = builder->classes(); AbstractMetaClass* classA = AbstractMetaClass::findClass(classes, u"A"); QCOMPARE(classA->typeEntry()->codeSnips().size(), 1); } void TestCodeInjections::testInjectWithInvalidApiVersion() { const char* cppCode ="struct A {};\n"; const char* xmlCode = "\ \n\ \n\ \n\ test Inject code\n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, true, u"0.1"_s)); QVERIFY(!builder.isNull()); AbstractMetaClassList classes = builder->classes(); const AbstractMetaClass *classA = AbstractMetaClass::findClass(classes, u"A"); QCOMPARE(classA->typeEntry()->codeSnips().size(), 0); } void TestCodeInjections::testTextStream() { StringStream str(TextStream::Language::Cpp); str << "void foo(int a, int b) {\n"; { Indentation i(str); str << "if (a == b)\n" << indent << "return a;\n" << outdent << "#if Q_OS_WIN\nprint()\n#endif\nreturn a + b;\n"; } str << "}\n\n// A table\n|" << AlignedField("bla", 40, QTextStream::AlignRight) << "|\n|" << AlignedField("bla", 40, QTextStream::AlignLeft) << "|\n|" << AlignedField(QString(), 40, QTextStream::AlignLeft) << "|\n"; str << "\n2nd table\n|" << AlignedField("bla", 3, QTextStream::AlignLeft) << '|' << AlignedField(QString{}, 0, QTextStream::AlignLeft) << "|\n"; static const char expected[] = R"(void foo(int a, int b) { if (a == b) return a; #if Q_OS_WIN print() #endif return a + b; } // A table | bla| |bla | | | 2nd table |bla|| )"; QCOMPARE(str.toString(), QLatin1String(expected)); } void TestCodeInjections::testTextStreamRst() { // Test that sphinx error: "Inline strong start-string without end-string." // is avoided, that is, characters following a formatting end are escaped. StringStream str; str << rstBold << "QObject" << rstBoldOff << "'s properties..." << rstItalic << "some italic" << rstItalicOff << " followed by space."; static const char16_t expected[] = uR"(**QObject**\'s properties...*some italic* followed by space.)"; QCOMPARE(str.toString(), expected); } QTEST_APPLESS_MAIN(TestCodeInjections)