m
magrif13. April 2020 13:28

Какая структура проекта предпочтительнее, если присутствуют тесты?

test, tdd, qt, QTest, c++

Добрый день. Решил тут добавить бенчмарков из QtTest в проект и столкнулся с вопросом, а как же всё-таки правильно организовать структуру папок проекта в таком случае. Из активного гугления выделил следующие подходы, основанные на создании подпроектов:
1. Проект делится на подпроекты ( TEMPLATE = subdirs ) по папкам - src где исходный код проекта ну и tests с тестами классов из src . В этом случае классы в тестах подключаются как ../src/MyClass.cpp . При таком подходе, очевидно, необходимо дважды компилировать один и тот же код, что не есть хорошо. Также надо все тестируемые классы добавлять подпроект тестов, и при их обилии тоже не красиво. Тут пример как раз такой реализации (в cmake только).
2. В этой статье товарищ предлагает интересный подход. Идея заключается в том, чтобы разделить проект также на три части - app , lib и test - причем весь проект лежит в lib , а в app один только main.cpp . Тут двойной компиляции не происходит, и проект lib компонуется либо с app , либо с test . Этот подход мне показался довольно интересным.
3. Здесь был предложена интересная идея, которая может базироваться на 1 или 2. Подпроект test поделить ещё на кучу мини-подпроектов, каждый из которых интерактивно даёт возможность внешнему пользователю ознакомиться с интерфейсами того или иного класса.

Какие из этих подходов вы бы [не]использовали? Почему? Какие посоветуете использовать или сами используете?

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

3
Evgenii Legotckoi
  • 14. April 2020 03:40
  • (bearbeitet)

Добрый день.

При использовании TEMPLATE = subdirs не обязательно будет двойная компиляция. subdirs позволяет компилировать проект в несколько библиотек, которые используются несколькими запускаемыми проектами, то есть как вы сказали app и тесты.
По сути все три подхода, что вы описали - это одно и тоже, различаются только уровнем детализации. И во всех подходах будет использоваться организация проекта через subdirs .

Чтобы минимизировать перекомпиляцию нужно проект разделить на библиотеки, которые будут отвечать каждая за свой уровень, то есть, например,

  • Data
  • Models
  • Views
  • и т.д.

Потом добавить в subdirs проекты самого приложения app, где по сути будет только main.cpp, а также проекты тестов. Тесты лучше разделять на логические небольшие кусочки, как в третьем подходе, чтобы тестировались отдельные части, только изменения одного теста не будет приводить к большой перекомпиляции, а изменение в одной библиотеке не будет приводить к перекомпиляции всех тестов.

    m
    • 16. April 2020 15:22

    А Вы в своих проектах делаете так, что только один main.cpp в app остаётся, а всё остальное в статических библиотеках, или же что-то ещё оставляете в app ? Просто нигде не видел такого, как в 2-м подходе.

      Evgenii Legotckoi
      • 17. April 2020 04:11
      • Die Antwort wurde als Lösung markiert.

      У нас в app части кроме main.cpp есть ещё несколько файлов, которые очень специфичны для самого app.
      У нас подобный подход имеет несколько причин.

      • Во-первых, всё-таки не так много существует проектов, которым подобное разделение требуется. У большинства проектов нет такого объёма кода, чтобы делить на библиотеки и пытаться оптимизировать сборку. То есть в большинстве случаев достаточно просто иметь нормальный ПК. А у нас в проекте уже на данный момент находится около 100000 файлов.
      • Во-вторых, подобное разделение на библиотеки позволяет управлять сложностью проекта. Что позволяет унифицировать интерфейсы и классы. В противном случае был бы бардак и изменение кода было бы очень болезненным.
      • В-третьих, у нас общая кодовая база для четырех программных продуктов и имеется в проекте четыре pro-файла для каждого программного продукта. То есть четыре app, в каждом свои погремушки по мелочи. Как результат, размер самих исполняемых файлов около 15 Мб, а остальные 1,5 Гб - это библиотеки.
      • Соответственно тесты тоже как отдельные pro проекты, чтобы не мешать всё в общую кучу.

        Kommentare

        Nur autorisierte Benutzer können Kommentare posten.
        Bitte Anmelden oder Registrieren
        Letzte Kommentare
        A
        ALO1ZE19. Oktober 2024 08:19
        Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
        ИМ
        Игорь Максимов5. Oktober 2024 07:51
        Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
        d
        dblas55. Juli 2024 11:02
        QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        k
        kmssr8. Februar 2024 18:43
        Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
        Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
        Jetzt im Forum diskutieren
        J
        JacobFib17. Oktober 2024 03:27
        добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
        JW
        Jhon Wick1. Oktober 2024 15:52
        Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
        КГ
        Кирилл Гусарев27. September 2024 09:09
        Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
        F
        Fynjy22. Juli 2024 04:15
        при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

        Folgen Sie uns in sozialen Netzwerken