m
magrifСәуір 13, 2020, 1: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
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

3
Evgenii Legotckoi
  • Сәуір 14, 2020, 3:40 Т.Ж.
  • (өңделген)

Добрый день.

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

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

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

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

    m
    • Сәуір 16, 2020, 3:22 Т.Қ.

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

      Evgenii Legotckoi
      • Сәуір 17, 2020, 4:11 Т.Ж.
      • Жауап шешім ретінде белгіленді.

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

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

        Пікірлер

        Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
        Кіріңіз немесе Тіркеліңіз
        Г

        C++ - Тест 001. Первая программа и типы данных

        • Нәтиже:66ұпай,
        • Бағалау ұпайлары-1
        t

        C++ - Тест 001. Первая программа и типы данных

        • Нәтиже:33ұпай,
        • Бағалау ұпайлары-10
        t

        Qt - Тест 001. Сигналы и слоты

        • Нәтиже:52ұпай,
        • Бағалау ұпайлары-4
        Соңғы пікірлер
        G
        GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
        Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
        d
        dblas5Шілде 5, 2024, 11:02 Т.Ж.
        QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        k
        kmssrАқп. 8, 2024, 6:43 Т.Қ.
        Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
        АК
        Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
        Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
        Енді форумда талқылаңыз
        Evgenii Legotckoi
        Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
        F
        FynjyШілде 22, 2024, 4:15 Т.Ж.
        при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
        BlinCT
        BlinCTМаусым 25, 2024, 1 Т.Ж.
        Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
        BlinCT
        BlinCTМамыр 5, 2024, 5:46 Т.Ж.
        Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
        Evgenii Legotckoi
        Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
        Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

        Бізді әлеуметтік желілерде бақылаңыз