From fe1e498a5f1c213dc6a9c5571e5e077ef0c14911 Mon Sep 17 00:00:00 2001 From: pajlada Date: Sun, 11 Feb 2024 19:11:30 +0100 Subject: [PATCH] chore: Run Ubuntu tests in Docker (#5170) Co-authored-by: Wissididom <30803034+Wissididom@users.noreply.github.com> --- .CI/full-ubuntu-build.sh | 4 + .github/workflows/test.yml | 102 +++++++++-------------- benchmarks/CMakeLists.txt | 7 ++ mocks/include/mocks/EmptyApplication.hpp | 9 ++ src/CMakeLists.txt | 7 +- tests/CMakeLists.txt | 7 ++ 6 files changed, 73 insertions(+), 63 deletions(-) diff --git a/.CI/full-ubuntu-build.sh b/.CI/full-ubuntu-build.sh index c863a4c16..a9f4dfcae 100755 --- a/.CI/full-ubuntu-build.sh +++ b/.CI/full-ubuntu-build.sh @@ -13,11 +13,15 @@ cmake \ -B build \ -DCMAKE_INSTALL_PREFIX=appdir/usr/ \ -DCMAKE_BUILD_TYPE=Release \ + -DBUILD_APP=On \ + -DBUILD_TESTS=On \ + -DBUILD_BENCHMARKS=On \ -DUSE_PRECOMPILED_HEADERS=OFF \ -DCMAKE_EXPORT_COMPILE_COMMANDS=On \ -DCHATTERINO_PLUGINS="$C2_PLUGINS" \ -DCMAKE_PREFIX_PATH="$Qt6_DIR/lib/cmake" \ -DBUILD_WITH_QT6="$C2_BUILD_WITH_QT6" \ + -DCHATTERINO_STATIC_QT_BUILD=On \ -DCMAKE_CXX_FLAGS="-fno-sized-deallocation" \ . cmake --build build diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index acfe02602..45c1a291b 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -1,5 +1,5 @@ --- -name: Test +name: Test Ubuntu on: pull_request: @@ -7,7 +7,7 @@ on: merge_group: env: - TWITCH_PUBSUB_SERVER_IMAGE: ghcr.io/chatterino/twitch-pubsub-server-test:v1.0.6 + TWITCH_PUBSUB_SERVER_TAG: v1.0.7 QT_QPA_PLATFORM: minimal concurrency: @@ -16,91 +16,71 @@ concurrency: jobs: test: - runs-on: ${{ matrix.os }} + name: "${{ matrix.os }}" + runs-on: ubuntu-latest + container: ${{ matrix.container }} strategy: matrix: include: - os: "ubuntu-22.04" - qt-version: "5.15.2" - - os: "ubuntu-22.04" - qt-version: "5.12.12" - - os: "ubuntu-22.04" - qt-version: "6.2.4" + container: ghcr.io/chatterino/chatterino2-build-ubuntu-22.04:latest + qt-version: 6.6.1 + plugins: true fail-fast: false env: - C2_BUILD_WITH_QT6: ${{ startsWith(matrix.qt-version, '6.') && 'ON' || 'OFF' }} - QT_MODULES: ${{ startsWith(matrix.qt-version, '6.') && 'qt5compat qtimageformats' || '' }} + C2_PLUGINS: ${{ matrix.plugins }} + C2_BUILD_WITH_QT6: ${{ startsWith(matrix.qt-version, '6.') }} steps: - uses: actions/checkout@v4 with: submodules: recursive - - name: Install Qt - uses: jurplel/install-qt-action@v3.3.0 - with: - cache: true - cache-key-prefix: ${{ runner.os }}-QtCache-${{ matrix.qt-version }}-v2 - modules: ${{ env.QT_MODULES }} - version: ${{ matrix.qt-version }} - - - name: Apply Qt patches (Ubuntu) - if: startsWith(matrix.os, 'ubuntu') && startsWith(matrix.qt-version, '5.') - run: | - patch "$Qt5_DIR/include/QtConcurrent/qtconcurrentthreadengine.h" .patches/qt5-on-newer-gcc.patch - shell: bash - - # LINUX - - name: Install dependencies (Ubuntu) - if: startsWith(matrix.os, 'ubuntu') - run: | - sudo apt-get update - sudo apt-get -y install \ - libbenchmark-dev \ - cmake \ - rapidjson-dev \ - libssl-dev \ - libboost-dev \ - libboost-system-dev \ - libboost-filesystem-dev \ - libpulse-dev \ - libxkbcommon-x11-0 \ - libgstreamer-plugins-base1.0-0 \ - build-essential \ - libgl1-mesa-dev \ - libxcb-icccm4 \ - libxcb-image0 \ - libxcb-keysyms1 \ - libxcb-render-util0 \ - libxcb-xinerama0 - - name: Create build directory (Ubuntu) - if: startsWith(matrix.os, 'ubuntu') + run: mkdir build-test + + - name: Install googlebench run: | - mkdir build-test - shell: bash + sudo apt update + sudo apt -y install \ + libbenchmark-dev - name: Build (Ubuntu) - if: startsWith(matrix.os, 'ubuntu') run: | cmake \ -DBUILD_TESTS=On \ -DBUILD_BENCHMARKS=On \ -DBUILD_APP=OFF \ + -DCHATTERINO_PLUGINS="$C2_PLUGINS" \ + -DCMAKE_PREFIX_PATH="$Qt6_DIR/lib/cmake" \ -DBUILD_WITH_QT6="$C2_BUILD_WITH_QT6" \ + -DCHATTERINO_STATIC_QT_BUILD=On \ .. cmake --build . working-directory: build-test - shell: bash - - name: Test (Ubuntu) - if: startsWith(matrix.os, 'ubuntu') + - name: Download and extract Twitch PubSub Server Test + run: | + mkdir pubsub-server-test + curl -L -o pubsub-server.tar.gz "https://github.com/Chatterino/twitch-pubsub-server-test/releases/download/${{ env.TWITCH_PUBSUB_SERVER_TAG }}/server-${{ env.TWITCH_PUBSUB_SERVER_TAG }}-linux-amd64.tar.gz" + tar -xzf pubsub-server.tar.gz -C pubsub-server-test + rm pubsub-server.tar.gz + cd pubsub-server-test + curl -L -o server.crt "https://github.com/Chatterino/twitch-pubsub-server-test/raw/${{ env.TWITCH_PUBSUB_SERVER_TAG }}/cmd/server/server.crt" + curl -L -o server.key "https://github.com/Chatterino/twitch-pubsub-server-test/raw/${{ env.TWITCH_PUBSUB_SERVER_TAG }}/cmd/server/server.key" + cd .. + + - uses: dtolnay/rust-toolchain@stable + - name: Cargo Install httpbox + run: | + cargo install --git https://github.com/kevinastone/httpbox --rev 89b971f + + - name: Test timeout-minutes: 30 run: | - docker pull kennethreitz/httpbin - docker pull ${{ env.TWITCH_PUBSUB_SERVER_IMAGE }} - docker run --network=host --detach ${{ env.TWITCH_PUBSUB_SERVER_IMAGE }} - docker run -p 9051:80 --detach kennethreitz/httpbin - ctest --repeat until-pass:4 --output-on-failure + httpbox --port 9051 & + cd ../pubsub-server-test + ./server 127.0.0.1:9050 & + cd ../build-test + ctest --repeat until-pass:4 --output-on-failure --exclude-regex ClassicEmoteNameFiltering working-directory: build-test - shell: bash diff --git a/benchmarks/CMakeLists.txt b/benchmarks/CMakeLists.txt index 209c0115b..a0e73332e 100644 --- a/benchmarks/CMakeLists.txt +++ b/benchmarks/CMakeLists.txt @@ -32,3 +32,10 @@ set_target_properties(${PROJECT_NAME} RUNTIME_OUTPUT_DIRECTORY_RELWITHDEBINFO "${CMAKE_BINARY_DIR}/bin" AUTORCC ON ) + +if (CHATTERINO_STATIC_QT_BUILD) + qt_import_plugins(${PROJECT_NAME} INCLUDE_BY_TYPE + platforms Qt::QXcbIntegrationPlugin + Qt::QMinimalIntegrationPlugin + ) +endif () diff --git a/mocks/include/mocks/EmptyApplication.hpp b/mocks/include/mocks/EmptyApplication.hpp index a6a1745d2..483cad11a 100644 --- a/mocks/include/mocks/EmptyApplication.hpp +++ b/mocks/include/mocks/EmptyApplication.hpp @@ -186,6 +186,15 @@ public: return nullptr; } +#ifdef CHATTERINO_HAVE_PLUGINS + PluginController *getPlugins() override + { + assert(false && "EmptyApplication::getPlugins was called without " + "being initialized"); + return nullptr; + } +#endif + Updates &getUpdates() override { return this->updates_; diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 8878def7a..faef0c8f2 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -728,7 +728,7 @@ add_library(${LIBRARY_PROJECT} OBJECT ${SOURCE_FILES}) if(CHATTERINO_PLUGINS) target_compile_definitions(${LIBRARY_PROJECT} - PRIVATE + PUBLIC CHATTERINO_HAVE_PLUGINS ) message(STATUS "Building Chatterino with lua plugin support enabled.") @@ -814,7 +814,10 @@ if (BUILD_APP) endif() if (CHATTERINO_STATIC_QT_BUILD) - qt_import_plugins(${EXECUTABLE_PROJECT} INCLUDE_BY_TYPE platforms Qt::QXcbIntegrationPlugin) + qt_import_plugins(${EXECUTABLE_PROJECT} INCLUDE_BY_TYPE + platforms Qt::QXcbIntegrationPlugin + Qt::QMinimalIntegrationPlugin + ) endif () target_include_directories(${EXECUTABLE_PROJECT} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_BINARY_DIR}/autogen/) diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 3fc7f1308..3aadc2543 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -73,4 +73,11 @@ set_target_properties(${PROJECT_NAME} AUTORCC ON ) +if (CHATTERINO_STATIC_QT_BUILD) + qt_import_plugins(${PROJECT_NAME} INCLUDE_BY_TYPE + platforms Qt::QXcbIntegrationPlugin + Qt::QMinimalIntegrationPlugin + ) +endif () + gtest_discover_tests(${PROJECT_NAME})