X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=.gitlab-ci.yml;h=70a17199e711c3cf0422b3992b167900d8c2c25a;hb=fb4be45e6f9ae9edb69614c6e4f04e0a7376520f;hp=d655aeae8486fa384dd95af49f55f47e024c7644;hpb=66066ffa03dd1036fa26b132c5332bc9c854ee8d;p=platform%2Fupstream%2Fgstreamer.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index d655aea..70a1719 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,4 @@ include: - - remote: "https://gitlab.freedesktop.org/freedesktop/ci-templates/-/raw/14731f78c23c7b523a85a26a068ade9ac1ecd2f3/templates/ci-fairy.yml" - remote: "https://gitlab.freedesktop.org/freedesktop/ci-templates/-/raw/14731f78c23c7b523a85a26a068ade9ac1ecd2f3/templates/fedora.yml" - remote: "https://gitlab.freedesktop.org/freedesktop/ci-templates/-/raw/14731f78c23c7b523a85a26a068ade9ac1ecd2f3/templates/debian.yml" @@ -24,9 +23,9 @@ variables: # If you are hacking on them or need a them to rebuild, its enough # to change any part of the string of the image you want. ### - FEDORA_TAG: '2021-10-04.0' + FEDORA_TAG: '2021-10-05.0' INDENT_TAG: '2021-10-04.0' - WINDOWS_TAG: "2021-10-04.1" + WINDOWS_TAG: "2021-10-12.0" GST_UPSTREAM_REPO: 'gstreamer/gstreamer' FDO_UPSTREAM_REPO: 'gstreamer/gstreamer' @@ -64,6 +63,7 @@ variables: -Drtsp_server=enabled -Dvaapi=enabled -Dsharp=disabled + -Dgpl=enabled MESON_GST_WERROR: > -Dgstreamer:werror=true @@ -109,20 +109,20 @@ default: trigger: image: alpine:latest stage: 'trigger' + variables: + GIT_STRATEGY: none script: - echo "Trigger job done, now running the pipeline." rules: # If the MR is assigned to the Merge bot, trigger the pipeline automatically - if: '$CI_MERGE_REQUEST_ASSIGNEES == "gstreamer-merge-bot"' + # Alway run tests post merged + - if: '$CI_PROJECT_NAMESPACE == "gstreamer" && $CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' # When the assignee isn't the merge bot, require an explicit action to trigger the pipeline # to avoid wasting CI resources - if: '$CI_MERGE_REQUEST_ASSIGNEES != "gstreamer-merge-bot"' when: 'manual' allow_failure: false - # If this matches, it means the pipeline is running against either the main - # or a stable branch, so make it manual - - if: '$CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' - when: 'manual' .fedora image: variables: @@ -136,6 +136,8 @@ fedora amd64 docker: - '.fedora image' - '.fdo.container-build@fedora' stage: 'build docker' + needs: + - "trigger" .gst-indent image: variables: @@ -255,18 +257,6 @@ gst indent: fi # -# Check "allow-edit" checkbox on merge requests with ci-fairy -# -check allow-edit: - extends: '.fdo.ci-fairy' - needs: [] - stage: 'preparation' - script: - - ci-fairy check-merge-request --require-allow-collaboration - rules: - - if: '$CI_PIPELINE_SOURCE == "merge_request_event"' - -# # build setup templates # .build_template: &build @@ -343,6 +333,13 @@ check allow-edit: when: "always" paths: - 'meson-logs/' + rules: + # If this matches, it means the pipeline is running against either the main + # or a stable branch, so make it manual + - if: '$CI_PROJECT_NAMESPACE == "gstreamer" && $CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' + when: manual + - changes: + *modules_changes .build fedora x86_64: extends: @@ -353,9 +350,6 @@ check allow-edit: - "fedora amd64 docker" variables: MESON_ARGS: *simple_build - rules: - - changes: - *modules_changes build nodebug fedora x86_64: extends: @@ -367,16 +361,6 @@ build nodebug fedora x86_64: variables: MESON_ARGS: "${DEFAULT_MESON_ARGS} -Dsharp=enabled -Dgstreamer:gst_debug=false -Domx=enabled -Dgst-omx:target=generic ${MESON_BUILDTYPE_ARGS} ${MESON_GST_WERROR}" -build static fedora x86_64: - extends: '.build fedora x86_64' - variables: - MESON_BUILDTYPE_ARGS: "--default-library=static -Dintrospection=disabled -Ddoc=disabled" - -build static nodebug fedora x86_64: - extends: 'build nodebug fedora x86_64' - variables: - MESON_BUILDTYPE_ARGS: "--default-library=static -Dintrospection=disabled -Ddoc=disabled" - build clang fedora x86_64: extends: '.build fedora x86_64' variables: @@ -402,6 +386,10 @@ build clang fedora x86_64: -Dgst-plugins-base:pango=enabled -Dgst-plugins-good:cairo=enabled rules: + # If this matches, it means the pipeline is running against either the main + # or a stable branch, so make it manual + - if: '$CI_PROJECT_NAMESPACE == "gstreamer" && $CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' + when: manual - changes: *modules_changes before_script: @@ -443,26 +431,17 @@ build msys2 : # https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_preference_variables?view=powershell-6 - $ErrorActionPreference = "Stop" - # For some reason docker build hangs if this is included in the image, needs more troubleshooting - - $env:PATH += ';C:\msys64\usr\bin;C:\msys64\mingw64\bin;C:\msys64\mingw32\bin' - # Copied from https://github.com/msys2/setup-msys2/blob/master/main.js#L98 - - C:\msys64\usr\bin\bash -c "pacman-key --init && pacman-key --populate msys2 && pacman-key --refresh-keys || true" - - C:\msys64\usr\bin\bash -c "sed -i 's/^CheckSpace/#CheckSpace/g' /etc/pacman.conf" - - echo "Updating MSYS2" - - C:\msys64\usr\bin\bash -c "pacman -Syuu --noconfirm || echo Update failed, ignoring" - - echo "Killing all MSYS2 processes" - - taskkill /F /FI "MODULES eq msys-2.0.dll" - - echo "Completing MSYS2 update" - - C:\msys64\usr\bin\bash -c "pacman -Suu --noconfirm" - - echo "Installing needed MSYS2 packages" - - C:\msys64\usr\bin\bash -c "pacman -Sy --noconfirm --needed mingw-w64-x86_64-toolchain ninja" - + # Configure MSYS2 to use the UCRT64 environment, start in the same directory + # and inherit PATH + - $env:MSYSTEM = "UCRT64" + - $env:CHERE_INVOKING = "1" + - $env:MSYS2_PATH_TYPE = "inherit" # For some reason, options are separated by newline instead of space, so we # have to replace them first. - $env:MESON_ARGS = $env:MESON_ARGS.replace("`n"," ") # Replace forward slashes with backwards so bash doesn't complain - $env:_PROJECT_DIR = $env:CI_PROJECT_DIR.replace('\','/') - - C:\msys64\usr\bin\bash -c "meson build $env:MESON_ARGS && ninja -C build" + - C:\msys64\usr\bin\bash -lc "meson build $env:MESON_ARGS && ninja -C build" # ---- Tests ----- # @@ -494,6 +473,7 @@ build msys2 : - > ./gst-env.py gst-validate-launcher ${TEST_SUITE} + --check-bugs --dump-on-failure --mute --shuffle @@ -534,25 +514,18 @@ integration testsuites fedora: extends: '.test fedora x86_64' parallel: 4 variables: - EXTRA_VALIDATE_ARGS: "--timeout-factor=2 --retry-on-failures --check-bugs --parts=${CI_NODE_TOTAL} --part-index=${CI_NODE_INDEX}" + EXTRA_VALIDATE_ARGS: "--timeout-factor=2 --retry-on-failures --parts=${CI_NODE_TOTAL} --part-index=${CI_NODE_INDEX} --sync" TEST_SUITE: "validate ges" # gstreamer-full: -# introspection has been disabled as the static build does not support it. -# See https://gitlab.freedesktop.org/gstreamer/gst-build/-/issues/162 -gstreamer-full: - extends: 'build static fedora x86_64' - stage: integrate +gstreamer-full static build: + extends: '.build fedora x86_64' + stage: 'build' variables: MESON_ARGS: > --default-library=static - -Dintrospection=disabled + -Ddoc=disabled $MESON_GST_WERROR - rules: - - changes: - - "*" - - scripts/* - - subprojects/gst-ci/**/* script: - *build @@ -563,12 +536,14 @@ gstreamer-full: paths: - 'meson-logs/' -gstreamer-full-minimal: - extends: 'build static fedora x86_64' - stage: integrate +gstreamer-full-minimal static build: + extends: 'gstreamer-full static build' + stage: 'build' variables: MESON_ARGS: > --default-library=static + -Ddoc=disabled + -Dgstreamer:gst_debug=false -Dauto_features=disabled -Dgstreamer:check=enabled -Dtests=enabled @@ -580,8 +555,6 @@ gstreamer-full-minimal: -Dgst-full-device-providers=alsa:alsadeviceprovider -Dgst-full-dynamic-types=pbtypes:video_multiview_flagset $MESON_GST_WERROR - rules: - - if: '$CI_PROJECT_NAME =~ /^(gst-build|gst-ci)$/' script: - *build @@ -610,7 +583,7 @@ valgrind core: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci/**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* @@ -622,7 +595,7 @@ valgrind base: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci//**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* - subprojects/gst-plugins-base/**/* @@ -637,7 +610,7 @@ valgrind good: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci/**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* - subprojects/gst-plugins-base/**/* @@ -651,7 +624,7 @@ valgrind ugly: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci/**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* - subprojects/gst-plugins-base/**/* @@ -666,7 +639,7 @@ valgrind bad: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci/**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* - subprojects/gst-plugins-base/**/* @@ -681,7 +654,7 @@ valgrind ges: - changes: - "*" - scripts/* - - subprojects/gst-ci/**/* + - ci/**/* - subprojects/gst-devtools/**/* - subprojects/gstreamer/**/* - subprojects/gst-plugins-base/**/* @@ -700,7 +673,9 @@ valgrind ges: MESON_BUILDTYPE_ARGS: "-Ddoc=enabled" CI_ARTIFACTS_URL: "${CI_PROJECT_URL}/-/jobs/${CI_JOB_ID}/artifacts/raw/" script: + # FIXME: should rebuild the image with newer versions! - pip3 install --upgrade hotdoc + - pip3 install --upgrade meson - *build - ./gst-env.py ninja -C build/ plugins_doc_caches - ./ci/scripts/check-documentation-diff.py @@ -715,7 +690,7 @@ valgrind ges: - plugins-cache-diffs/ # -# This jobs runs in gsrtreamer namespace when after the merge into main branch. +# This jobs runs in gstreamer namespace when after the merge into main branch. # The produced artifact is later used to automatically update the web page. # documentation: @@ -736,9 +711,10 @@ build documentation: stage: build needs: - "trigger" - - stage: build rules: + # Never run post merge, we have the `documentation` always running for that + - if: '$CI_PROJECT_NAMESPACE == "gstreamer" && $CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' + when: never - changes: - .gitlab-ci.yml - ci/gitlab/freedesktop_doc_importer.sh @@ -760,21 +736,21 @@ build documentation: # https://gitlab.com/gitlab-org/gitlab/-/issues/341737 cerbero trigger: stage: build - image: $FEDORA_IMAGE + extends: + - '.fedora image' + - '.fdo.suffixed-image@fedora' needs: - "fedora amd64 docker" script: - - python3 -m pip install --user python-gitlab - ci/gitlab/trigger_cerbero_pipeline.py - variables: - # Use GST_UPSTREAM_BRANCH - UPSTREAM_BRANCH: 'main' - rules: + # Never run post merge + - if: '$CI_PROJECT_NAMESPACE == "gstreamer" && $CI_COMMIT_BRANCH == $GST_UPSTREAM_BRANCH' + when: never - changes: - .gitlab-ci.yml - - ci/gitlab/tigger_cerbero_pipeline.py + - ci/gitlab/trigger_cerbero_pipeline.py - subprojects/gst-devtools/**/* - subprojects/gst-editing-services/**/* - subprojects/gst-libav/**/*