diff --git a/.github/workflows/ci-doc-check.yml b/.github/workflows/ci-doc-check.yml deleted file mode 100644 index 9531228a1e..0000000000 --- a/.github/workflows/ci-doc-check.yml +++ /dev/null @@ -1,77 +0,0 @@ -name: "CI - Documentation Check" - -on: - push: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used below for the pull request event. Keep both lists in sync!! - - # this file as well - - .github/workflows/ci-doc-check.yml - # all Ruby files - - service/Gemfile* - - service/*.gemspec - - service/**.rb - # the D-Bus introspection files - - doc/dbus/**.xml - - pull_request: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used above for the push event. Keep both lists in sync!! - - # this file as well - - .github/workflows/ci-doc-check.yml - # all Ruby files - - service/Gemfile* - - service/*.gemspec - - service/**.rb - # the D-Bus introspection files - - doc/dbus/**.xml - -jobs: - doc_check: - runs-on: ubuntu-latest - - container: - image: registry.opensuse.org/opensuse/tumbleweed:latest - - steps: - - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Fix the file owner - # fix the file owner - run: chown -R -c 0 . - - - name: Configure and refresh repositories - # disable unused repositories to have faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && zypper ref - - - name: Install Ruby development files and XML tooling - run: zypper --non-interactive install --no-recommends - gcc gcc-c++ make libopenssl-devel ruby-devel augeas-devel diff - libxslt-devel libxml2-devel xmlstarlet - - - name: Cache RubyGems - uses: actions/cache@v3 - with: - key: "Gemfile-${{ hashFiles('service/Gemfile.lock') }}" - path: service/vendor/bundle - - - name: Install RubyGems - env: - NOKOGIRI_USE_SYSTEM_LIBRARIES: 1 - run: | - bundle config set --local path 'vendor/bundle' - bundle install - working-directory: ./service - - - name: Generate doc - run: bundle exec yardoc --fail-on-warning - working-directory: ./service - - - name: Check that introspected API and its docs have not diverged - run: make check - working-directory: ./doc diff --git a/.github/workflows/ci-integration-tests.yml b/.github/workflows/ci-integration-tests.yml deleted file mode 100644 index 7f7fdf87cb..0000000000 --- a/.github/workflows/ci-integration-tests.yml +++ /dev/null @@ -1,164 +0,0 @@ -name: "CI - Integration Tests" - -on: - push: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used below for the pull request event. Keep both lists in sync!! - - # this file itself - - .github/workflows/ci-integration-tests.yml - - # the web frontend - - web/**.json - - web/**.html - - web/**.scss - - web/**.jsx? - # ignore unit tests, we do not run them here - - "!web/**.test.jsx?" - - web/Makefile - - # the service backend - - setup-service.sh - - service/lib/**.rb - - service/bin/agamactl - - service/Gemfile* - - service/*.gemspec - # D-Bus and systemd configs - - service/share/*.conf - - service/share/*.service - # Rust services - - rust/Cargo.lock - - rust/agama-dbus-server/** - - rust/agama-locale-data/** - - rust/agama-lib/** - # ignore the JSON profile and the examples - - "!rust/agama-lib/share/**" - - rust/share/*.service - - # the playwright tests and configs - - playwright/**.ts - - playwright/config/agama.yaml - - pull_request: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used above for the push event. Keep both lists in sync!! - - # this file itself - - .github/workflows/ci-integration-tests.yml - - # the web frontend - - web/**.json - - web/**.html - - web/**.scss - - web/**.jsx? - # ignore unit tests, we do not run them here - - "!web/**.test.jsx?" - - web/Makefile - - # the service backend - - setup-service.sh - - service/lib/**.rb - - service/bin/agamactl - - service/Gemfile* - - service/*.gemspec - # D-Bus and systemd configs - - service/share/*.conf - - service/share/*.service - # Rust services - - rust/Cargo.lock - - rust/agama-dbus-server/** - - rust/agama-locale-data/** - - rust/agama-lib/** - # ignore the JSON profile and the examples - - "!rust/agama-lib/share/**" - - rust/share/*.service - - # the playwright tests and configs - - playwright/**.ts - - playwright/config/agama.yaml - -jobs: - integration-tests: - timeout-minutes: 60 - runs-on: ubuntu-latest - - strategy: - fail-fast: false - matrix: - # TW is needed because of the Cockpit packages - distro: [ "tumbleweed" ] - - steps: - - # TODO: Reuse/share building the frontend and backend with the other steps - # TODO: Cache the Ruby gems and node packages - - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Created shared YaST log directory - run: mkdir -p /tmp/log/YaST2 - - - name: Start container - run: podman run --privileged --detach --name agama --ipc=host -e CI -e GITHUB_ACTIONS -v /dev:/dev -v .:/checkout -v /tmp/log/YaST2:/var/log/YaST2 registry.opensuse.org/systemsmanagement/agama/staging/containers/opensuse/agama-testing:latest - - - name: Environment - run: podman exec agama bash -c "env | sort" - - - name: Build the frontend - run: podman exec agama bash -c "cd /checkout/web && npm install && make" - - - name: Install the frontend - run: podman exec agama bash -c "ln -snfv /checkout/web/dist /usr/share/cockpit/agama" - - # ./setup-service.sh will try setting up cockpit.socket - # which has a login page, so this local-session needs to be first - - name: Start Cockpit service - run: podman exec --detach agama /usr/libexec/cockpit-ws --local-session=/usr/bin/cockpit-bridge - - - name: Setup service - run: podman exec agama bash -c "cd /checkout; ./setup-service.sh" - - - name: Set a testing Agama configuration - # copy a simplified ALP config file, it skips the product selection at the beginning - run: podman exec agama bash -c "cp /checkout/playwright/config/agama.yaml /checkout/service/etc/agama.yaml" - - - name: Show NetworkManager log - run: podman exec agama journalctl -u NetworkManager - - - name: Show the D-Bus services log - run: podman exec agama bash -c "journalctl | grep agama" - - - name: Check D-Bus socket - run: podman exec agama ls -l /var/run/dbus/system_bus_socket - - - name: Run the Agama smoke test - run: podman exec agama curl http://localhost:9090/cockpit/@localhost/agama/index.html - - - name: Check Playwright version - run: podman exec agama playwright --version - - - name: Run the Playwright tests - # user authentication is not required when cockpit runs a local session - # run the tests in the Chromium browser - run: podman exec agama bash -c "cd /checkout/playwright && SKIP_LOGIN=true playwright test --trace on --project chromium" - - - name: Again show the D-Bus services log - run: podman exec agama bash -c "journalctl | grep agama" - - - name: Show the complete journal - # maybe not necessary if the above filtered journalctl calls are enough - run: podman exec agama journalctl -b || echo "journal failed with $?" - - - name: Upload the test results - uses: actions/upload-artifact@v3 - # run even when the previous step fails - if: always() - with: - name: test-results - retention-days: 30 - path: | - playwright/test-results/**/* - /tmp/log/YaST2/y2log diff --git a/.github/workflows/ci-rubocop.yml b/.github/workflows/ci-rubocop.yml deleted file mode 100644 index 067ee6b367..0000000000 --- a/.github/workflows/ci-rubocop.yml +++ /dev/null @@ -1,54 +0,0 @@ -name: "CI - Rubocop" - -on: - push: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used below for the pull request event. Keep both lists in sync!! - - # this file as well - - .github/workflows/ci-rubocop.yml - # Rubocop configuration - - service/.rubocop.yml - # all Ruby files - - service/Gemfile - - service/bin/** - - service/**.rb - - pull_request: - paths: - # NOTE: GitHub Actions do not allow using YAML references, the same path - # list is used above for the push event. Keep both lists in sync!! - - # this file as well - - .github/workflows/ci-rubocop.yml - # Rubocop configuration - - service/.rubocop.yml - # all Ruby files - - service/Gemfile - - service/bin/** - - service/**.rb - -jobs: - rubocop: - runs-on: ubuntu-latest - - defaults: - run: - working-directory: ./service - - strategy: - fail-fast: false - matrix: - distro: [ "leap_latest" ] - - container: - image: registry.opensuse.org/yast/head/containers_${{matrix.distro}}/yast-ruby - - steps: - - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Rubocop - run: /usr/bin/rubocop.*-1.24.1 diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml deleted file mode 100644 index d941c5d41d..0000000000 --- a/.github/workflows/ci.yml +++ /dev/null @@ -1,169 +0,0 @@ -name: CI - -on: [push, pull_request] - -jobs: - frontend_build: - runs-on: ubuntu-latest - - defaults: - run: - working-directory: ./web - - strategy: - matrix: - node-version: ["18.x"] - # See supported Node.js release schedule at https://nodejs.org/en/about/releases/ - - steps: - - uses: actions/checkout@v3 - - - name: Use Node.js ${{ matrix.node-version }} - uses: actions/setup-node@v3 - with: - node-version: ${{ matrix.node-version }} - cache: 'npm' - cache-dependency-path: 'web/package-lock.json' - - - name: Install dependencies - run: npm install - - - name: Build the application - run: make - - - name: Run check spell - run: npm run cspell - - - name: Check types - run: npm run check-types - - - name: Run ESLint - run: npm run eslint - - - name: Run Stylelint - run: npm run stylelint - - - name: Run the tests and generate coverage report - run: npm test -- --coverage - - - name: Coveralls GitHub Action - uses: coverallsapp/github-action@v2 - with: - base-path: ./web - flag-name: frontend - parallel: true - - ruby_tests: - runs-on: ubuntu-latest - env: - COVERAGE: 1 - - defaults: - run: - working-directory: ./service - - strategy: - fail-fast: false - matrix: - distro: [ "tumbleweed" ] - - container: - image: registry.opensuse.org/yast/head/containers_${{matrix.distro}}/yast-ruby - - steps: - - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Configure and refresh repositories - # disable unused repositories to have faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && ( zypper ref || zypper ref || zypper ref ) - - - name: Install Ruby development files - run: zypper --non-interactive install gcc gcc-c++ make openssl-devel ruby-devel npm augeas-devel - - - name: Install required packages - run: zypper --non-interactive install yast2-iscsi-client - - - name: Install RubyGems dependencies - run: bundle config set --local with 'development' && bundle install - - - name: Run the tests and generate coverage report - run: bundle exec rspec - - - name: Coveralls GitHub Action - uses: coverallsapp/github-action@v2 - with: - base-path: ./service - flag-name: backend - parallel: true - - rust_ci: - runs-on: ubuntu-latest - env: - COVERAGE: 1 - - defaults: - run: - working-directory: ./rust - - strategy: - fail-fast: false - matrix: - distro: [ "tumbleweed" ] - - container: - image: registry.opensuse.org/yast/head/containers_${{matrix.distro}}/yast-ruby - options: --security-opt seccomp=unconfined - - steps: - - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Configure and refresh repositories - # disable unused repositories to have faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && ( zypper ref || zypper ref || zypper ref ) - - - name: Install Rust development files - run: zypper --non-interactive install rustup - - - name: Install required packages - run: zypper --non-interactive install python-langtable-data openssl-3 libopenssl-3-devel jq - - - name: Install Rust toolchains - run: rustup toolchain install stable - - - name: Install cargo-binstall - uses: taiki-e/install-action@v2 - with: - tool: cargo-binstall - - - name: Install Tarpaulin (for code coverage) - run: cargo-binstall --no-confirm cargo-tarpaulin - - - name: Run the tests - run: cargo tarpaulin --out xml - - - name: Lint formatting - run: cargo fmt --all -- --check - - - name: Coveralls GitHub Action - uses: coverallsapp/github-action@v2 - with: - base-path: ./rust - format: cobertura - flag-name: rust-backend - parallel: true - - finish: - runs-on: ubuntu-latest - - needs: [frontend_build, ruby_tests, rust_ci] - - steps: - - - name: Coveralls Finished - uses: coverallsapp/github-action@v1 - with: - parallel-finished: true diff --git a/.github/workflows/configure_osc.sh b/.github/workflows/configure_osc.sh deleted file mode 100755 index 193164b463..0000000000 --- a/.github/workflows/configure_osc.sh +++ /dev/null @@ -1,15 +0,0 @@ -#! /bin/bash - -# This helper script creates the "osc" configuration file with OBS credentials - -CONFIG_FILE="$HOME/.config/osc/oscrc" - -# do not overwrite the existing config accidentally -if [ -e "$CONFIG_FILE" ]; then - echo "ERROR: $CONFIG_FILE already exists" - exit 1 -fi - -TEMPLATE=$(dirname "${BASH_SOURCE[0]}")/oscrc.template -mkdir -p $(dirname "$CONFIG_FILE") -sed -e "s/@OBS_USER@/$OBS_USER/g" -e "s/@OBS_PASSWORD@/$OBS_PASSWORD/g" "$TEMPLATE" > "$CONFIG_FILE" diff --git a/.github/workflows/github-pages.yml b/.github/workflows/github-pages.yml deleted file mode 100644 index 9d3c6505b0..0000000000 --- a/.github/workflows/github-pages.yml +++ /dev/null @@ -1,68 +0,0 @@ -# Simple workflow for deploying static content to GitHub Pages -name: GitHub Pages - -on: - # Runs on pushes targeting the default branch - push: - branches: - - master - - # Allows you to run this workflow manually from the Actions tab - workflow_dispatch: - -# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages -permissions: - contents: read - pages: write - id-token: write - -# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. -# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. -concurrency: - group: "pages" - cancel-in-progress: false - -jobs: - # Single deploy job since we're just deploying - pages_deploy: - environment: - name: github-pages - url: ${{ steps.deployment.outputs.page_url }} - runs-on: ubuntu-latest - steps: - - name: Checkout - uses: actions/checkout@v3 - - - name: Install DocBook tooling - run: | - sudo apt-get update - sudo apt-get --assume-yes --no-install-recommends install xmlto docbook-xsl xmlstarlet - - - name: Build HTML via DocBook - run: make -C doc - - - name: Install Node.js - uses: actions/setup-node@v3 - with: - node-version: '18.x' - cache: 'npm' - cache-dependency-path: 'web/package-lock.json' - - - name: Install NPM packages - run: cd web && npm ci - - - name: Build the JSDoc documentation - run: cd web && npm run jsdoc && mv jsdoc.out ../doc/dist/jsdoc - - - name: Setup Pages - uses: actions/configure-pages@v3 - - - name: Upload artifact - uses: actions/upload-pages-artifact@v1 - with: - # upload the built docs - path: 'doc/dist' - - - name: Deploy to GitHub Pages - id: deployment - uses: actions/deploy-pages@v2 diff --git a/.github/workflows/migrate-wicked-ci.yml b/.github/workflows/migrate-wicked-ci.yml new file mode 100644 index 0000000000..e0fdfca314 --- /dev/null +++ b/.github/workflows/migrate-wicked-ci.yml @@ -0,0 +1,27 @@ +name: "migrate-wicked CI" + +on: [push, pull_request] + +env: + CARGO_TERM_COLOR: always + +jobs: + rust_ci: + runs-on: ubuntu-latest + + defaults: + run: + working-directory: ./rust/agama-migrate-wicked + + strategy: + fail-fast: false + + steps: + - name: Git Checkout + uses: actions/checkout@v3 + - name: Build + run: cargo build --verbose + - name: Run tests + run: cargo test --verbose + - name: Run lint tests + run: cargo fmt --all -- --check diff --git a/.github/workflows/migrate-wicked-integration-tests.yml b/.github/workflows/migrate-wicked-integration-tests.yml new file mode 100644 index 0000000000..ff76d1d473 --- /dev/null +++ b/.github/workflows/migrate-wicked-integration-tests.yml @@ -0,0 +1,23 @@ +name: "migrate-wicked CI - Integration Tests" + +on: [push, pull_request] + +env: + CARGO_TERM_COLOR: always + +jobs: + integration-tests: + runs-on: ubuntu-latest + + strategy: + fail-fast: false + + steps: + - name: Git Checkout + uses: actions/checkout@v3 + - name: Start container + run: podman run --privileged --detach --name migrate-wicked --ipc=host -e CARGO_TERM_COLOR=always -v /dev:/dev -v .:/checkout registry.opensuse.org/home/jcronenberg/github-ci/containers/opensuse/migrate-wicked-testing:latest + - name: Build migrate-wicked + run: podman exec migrate-wicked bash -c "cd /checkout/rust/agama-migrate-wicked/ && cargo build" + - name: Run migration integration tests + run: podman exec migrate-wicked bash -c "/checkout/rust/agama-migrate-wicked/tests/test.sh" diff --git a/.github/workflows/obs-release.yml b/.github/workflows/obs-release.yml deleted file mode 100644 index c31034c5fd..0000000000 --- a/.github/workflows/obs-release.yml +++ /dev/null @@ -1,39 +0,0 @@ -# Publish a new version -# - Submit the packages to systemsmanagement:Agama:Devel -# - Send submit requests - -name: Release - -on: - # runs when creating a release tag - push: - tags: - - v[0-9]* - -jobs: - # Note: cockpit-agama-playwright is currently not submitted - - update_rust: - uses: ./.github/workflows/obs-staging-shared.yml - # pass all secrets - secrets: inherit - with: - install_packages: obs-service-cargo_audit obs-service-cargo_vendor - project_name: systemsmanagement:Agama:Devel - package_name: agama-cli - - update_web: - uses: ./.github/workflows/obs-staging-shared.yml - # pass all secrets - secrets: inherit - with: - install_packages: obs-service-node_modules - project_name: systemsmanagement:Agama:Devel - package_name: cockpit-agama - - update_service: - uses: ./.github/workflows/obs-service-shared.yml - # pass all secrets - secrets: inherit - with: - project_name: systemsmanagement:Agama:Devel diff --git a/.github/workflows/obs-service-shared.yml b/.github/workflows/obs-service-shared.yml deleted file mode 100644 index 62a035e0a8..0000000000 --- a/.github/workflows/obs-service-shared.yml +++ /dev/null @@ -1,80 +0,0 @@ -# this is a shared workflow, not called as a top level workflow - -name: Update OBS Service Package - -on: - workflow_call: - secrets: - OBS_USER: - required: true - OBS_PASSWORD: - required: true - - inputs: - project_name: - description: OBS project name - required: true - type: string - -jobs: - update_service: - # do not run in forks - if: github.repository == 'openSUSE/agama' - - runs-on: ubuntu-latest - - container: - image: registry.opensuse.org/opensuse/tumbleweed:latest - - steps: - - name: Configure and refresh repositories - # disable unused repositories to have a faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && zypper ref - - - name: Install tools - run: zypper --non-interactive install --no-recommends - git - obs-service-format_spec_file - osc - ruby - 'rubygem(gem2rpm)' - 'rubygem(yast-rake)' - - - name: Git Checkout (full history) - if: ${{ github.ref_type != 'tag' }} - uses: actions/checkout@v3 - with: - # fetch all history, we need to find the latest tag and offset for the version number - fetch-depth: 0 - - - name: Git Checkout (release tag only) - if: ${{ github.ref_type == 'tag' }} - uses: actions/checkout@v3 - - - name: Fix file owner - # workaround for a strict git check - run: chown -R -c 0 . - - - name: Configure osc - run: .github/workflows/configure_osc.sh - env: - OBS_USER: ${{ secrets.OBS_USER }} - OBS_PASSWORD: ${{ secrets.OBS_PASSWORD }} - - - name: Commit the rubygem-agama package to ${{ inputs.project_name }} - run: rake osc:commit - working-directory: ./service - env: - # do not build the package with "osc", it takes long time - # and does not provide much value - SKIP_OSC_BUILD: 1 - OBS_PROJECT: ${{ inputs.project_name }} - - - name: Submit the rubygem-agama package - # only when a tag has been pushed - if: ${{ github.ref_type == 'tag' }} - # the package has been comitted in the previous step, just submit it - run: rake osc:sr:force - working-directory: ./service - env: - OBS_PROJECT: ${{ inputs.project_name }} diff --git a/.github/workflows/obs-staging-playwright.yml b/.github/workflows/obs-staging-playwright.yml deleted file mode 100644 index 3c9d58bc87..0000000000 --- a/.github/workflows/obs-staging-playwright.yml +++ /dev/null @@ -1,19 +0,0 @@ -name: Submit cockpit-agama-playwright - -on: - # runs on pushes targeting the default branch - push: - branches: - - master - paths: - # run only when a Playwright source is changed - - playwright/** - -jobs: - update_staging: - uses: ./.github/workflows/obs-staging-shared.yml - # pass all secrets - secrets: inherit - with: - project_name: systemsmanagement:Agama:Staging - package_name: cockpit-agama-playwright diff --git a/.github/workflows/obs-staging-rust.yml b/.github/workflows/obs-staging-rust.yml deleted file mode 100644 index b83f6759f7..0000000000 --- a/.github/workflows/obs-staging-rust.yml +++ /dev/null @@ -1,20 +0,0 @@ -name: Submit agama-cli - -on: - # runs on pushes targeting the default branch - push: - branches: - - master - paths: - # run only when a Rust source is changed - - rust/** - -jobs: - update_staging: - uses: ./.github/workflows/obs-staging-shared.yml - # pass all secrets - secrets: inherit - with: - install_packages: obs-service-cargo_audit obs-service-cargo_vendor - project_name: systemsmanagement:Agama:Staging - package_name: agama-cli diff --git a/.github/workflows/obs-staging-service.yml b/.github/workflows/obs-staging-service.yml deleted file mode 100644 index 5d3cb47bf5..0000000000 --- a/.github/workflows/obs-staging-service.yml +++ /dev/null @@ -1,19 +0,0 @@ -name: Submit rubygem-agama - -on: - # runs on pushes targeting the default branch - push: - branches: - - master - paths: - # run only when a service source is changed - - service/** - - Rakefile - -jobs: - update_service: - uses: ./.github/workflows/obs-service-shared.yml - # pass all secrets - secrets: inherit - with: - project_name: systemsmanagement:Agama:Staging diff --git a/.github/workflows/obs-staging-shared.yml b/.github/workflows/obs-staging-shared.yml deleted file mode 100644 index 55eae4315e..0000000000 --- a/.github/workflows/obs-staging-shared.yml +++ /dev/null @@ -1,90 +0,0 @@ -# this is a shared workflow, not called as a top level workflow - -name: Update OBS Packages - -on: - workflow_call: - secrets: - OBS_USER: - required: true - OBS_PASSWORD: - required: true - - inputs: - install_packages: - description: Additional packages to install - required: false - type: string - - package_name: - description: OBS package name - required: true - type: string - - project_name: - description: OBS project name - required: true - type: string - -jobs: - update_staging_package: - # do not run in forks - if: github.repository == 'openSUSE/agama' - - runs-on: ubuntu-latest - - container: - image: registry.opensuse.org/opensuse/tumbleweed:latest - - steps: - - name: Git Checkout - uses: actions/checkout@v3 - - - name: Configure and refresh repositories - # disable unused repositories to have a faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && zypper ref - - - name: Install tools - run: zypper --non-interactive install --no-recommends - cpio - obs-service-download_files - obs-service-format_spec_file - obs-service-obs_scm - osc - ${{ inputs.install_packages }} - - - name: Configure osc - run: .github/workflows/configure_osc.sh - env: - OBS_USER: ${{ secrets.OBS_USER }} - OBS_PASSWORD: ${{ secrets.OBS_PASSWORD }} - - - name: Checkout ${{ inputs.package_name }} - run: osc co ${{ inputs.project_name }} ${{ inputs.package_name }} - - - name: Update service revision - # only when a tag has been pushed - if: ${{ github.ref_type == 'tag' }} - run: |- - echo "Updating revision to ${{ github.ref_name }}" - sed -i -e 's#.*#${{ github.ref_name }}#' _service - working-directory: ./${{ inputs.project_name }}/${{ inputs.package_name }} - - - name: Run services - run: osc service manualrun - working-directory: ./${{ inputs.project_name }}/${{ inputs.package_name }} - - - name: Check status - run: osc diff && osc status - working-directory: ./${{ inputs.project_name }}/${{ inputs.package_name }} - - - name: Commit ${{ inputs.package_name }} - run: |- - osc commit -m "Updated to $(sed -e '/^version:/!d' -e 's/version: *\(.*\)/\1/' agama.obsinfo) ($(sed -e '/^commit:/!d' -e 's/commit: *\(.*\)/\1/' agama.obsinfo))" - working-directory: ./${{ inputs.project_name }}/${{ inputs.package_name }} - - - name: Submit the package - # only when a tag has been pushed - if: ${{ github.ref_type == 'tag' }} - run: osc sr --yes -m "Releasing version ${{ github.ref_name }}" - working-directory: ./${{ inputs.project_name }}/${{ inputs.package_name }} diff --git a/.github/workflows/obs-staging-web.yml b/.github/workflows/obs-staging-web.yml deleted file mode 100644 index fa2a9731f8..0000000000 --- a/.github/workflows/obs-staging-web.yml +++ /dev/null @@ -1,20 +0,0 @@ -name: Submit cockpit-agama - -on: - # runs on pushes targeting the default branch - push: - branches: - - master - paths: - # run only when a web frontend source is changed - - web/** - -jobs: - update_staging: - uses: ./.github/workflows/obs-staging-shared.yml - # pass all secrets - secrets: inherit - with: - install_packages: obs-service-node_modules - project_name: systemsmanagement:Agama:Staging - package_name: cockpit-agama diff --git a/.github/workflows/oscrc.template b/.github/workflows/oscrc.template deleted file mode 100644 index e6133a0677..0000000000 --- a/.github/workflows/oscrc.template +++ /dev/null @@ -1,7 +0,0 @@ -[general] -apiurl = https://api.opensuse.org - -[https://api.opensuse.org] -user=@OBS_USER@ -pass=@OBS_PASSWORD@ -credentials_mgr_class=osc.credentials.PlaintextConfigFileCredentialsManager diff --git a/.github/workflows/weblate-merge-po.yml b/.github/workflows/weblate-merge-po.yml deleted file mode 100644 index 244e9b2aa9..0000000000 --- a/.github/workflows/weblate-merge-po.yml +++ /dev/null @@ -1,110 +0,0 @@ -name: Weblate Merge PO - -on: - schedule: - # run every Monday at 2:42AM UTC - - cron: "42 2 * * 0" - - # allow running manually - workflow_dispatch: - -jobs: - merge-po: - # allow pushing and creating pull requests - permissions: - contents: write - pull-requests: write - - # do not run in forks - if: github.repository == 'openSUSE/agama' - - runs-on: ubuntu-latest - - container: - image: registry.opensuse.org/opensuse/tumbleweed:latest - - steps: - - name: Configure and refresh repositories - run: | - # install the GitHub command line tool "gh" - zypper addrepo https://cli.github.com/packages/rpm/gh-cli.repo - # disable unused repositories to have a faster refresh - zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && \ - zypper --non-interactive --gpg-auto-import-keys ref - - - name: Install tools - run: zypper --non-interactive install --no-recommends gh git gettext-tools - - - name: Configure Git - run: | - git config --global user.name "YaST Bot" - git config --global user.email "yast-devel@opensuse.org" - - - name: Checkout sources - uses: actions/checkout@v3 - with: - path: agama - - - name: Checkout Agama-weblate sources - uses: actions/checkout@v3 - with: - path: agama-weblate - repository: openSUSE/agama-weblate - - - name: Update PO files - working-directory: ./agama - run: | - mkdir -p web/po - # delete the current translations - find web/po -name '*.po' -exec git rm '{}' ';' - - # copy the new ones - mkdir -p web/po - cp -a ../agama-weblate/web/*.po web/po - git add web/po/*.po - - - name: Validate the PO files - working-directory: ./agama - run: ls web/po/*.po | xargs -n1 msgfmt --check-format -o /dev/null - - # any changes besides the timestamps in the PO files? - - name: Check changes - id: check_changes - working-directory: ./agama - run: | - git diff --staged --ignore-matching-lines="POT-Creation-Date:" \ - --ignore-matching-lines="PO-Revision-Date:" web/po > po.diff - - if [ -s po.diff ]; then - echo "PO files updated" - # this is an Output Parameter - # https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#setting-an-output-parameter - echo "po_updated=true" >> $GITHUB_OUTPUT - else - echo "PO files unchanged" - echo "po_updated=false" >> $GITHUB_OUTPUT - fi - - rm po.diff - - - name: Push updated PO files - # run only when a PO file has been updated - if: steps.check_changes.outputs.po_updated == 'true' - working-directory: ./agama - run: | - # use a unique branch to avoid possible conflicts with already existing branches - git checkout -b "po_merge_${GITHUB_RUN_ID}" - git commit -a -m "Update PO files"$'\n\n'"Agama-weblate commit: `git -C ../agama-weblate rev-parse HEAD`" - git push origin "po_merge_${GITHUB_RUN_ID}" - - - name: Create pull request - # run only when a PO file has been updated - if: steps.check_changes.outputs.po_updated == 'true' - working-directory: ./agama - run: | - gh pr create -B master -H "po_merge_${GITHUB_RUN_ID}" \ - --label translations --label bot \ - --title "Update PO files" \ - --body "Updating the translation files from the agama-weblate repository" - env: - GH_TOKEN: ${{ github.token }} diff --git a/.github/workflows/weblate-update-pot.yml b/.github/workflows/weblate-update-pot.yml deleted file mode 100644 index a833ce1284..0000000000 --- a/.github/workflows/weblate-update-pot.yml +++ /dev/null @@ -1,81 +0,0 @@ -name: Weblate Update POT - -on: - schedule: - # run every working day (Monday-Friday) at 1:42AM UTC - - cron: "42 1 * * 0-4" - - # allow running manually - workflow_dispatch: - -jobs: - update-pot: - # do not run in forks - if: github.repository == 'openSUSE/agama' - - runs-on: ubuntu-latest - - container: - image: registry.opensuse.org/opensuse/tumbleweed:latest - - steps: - - name: Configure and refresh repositories - # disable unused repositories to have a faster refresh - run: zypper modifyrepo -d repo-non-oss repo-openh264 repo-update && zypper ref - - - name: Install tools - run: zypper --non-interactive install --no-recommends diffutils git gettext-tools - - - name: Checkout Agama sources - uses: actions/checkout@v3 - with: - path: agama - - - name: Generate POT file - run: | - cd agama/web - ./build_pot - msgfmt --statistics agama.pot - - - name: Validate the generated POT file - run: msgfmt --check-format agama/web/agama.pot - - - name: Checkout Weblate sources - uses: actions/checkout@v3 - with: - path: agama-weblate - repository: openSUSE/agama-weblate - token: ${{ secrets.GH_TOKEN }} - - - name: Configure Git - run: | - git config --global user.name "YaST Bot" - git config --global user.email "yast-devel@opensuse.org" - - - name: Update POT file - run: | - mkdir -p agama-weblate/web - cp agama/web/agama.pot agama-weblate/web/agama.pot - - # any change besides the timestamp in the POT file? - - name: Check changes - id: check_changes - run: | - git -C agama-weblate diff --ignore-matching-lines="POT-Creation-Date:" web/agama.pot > pot.diff - - if [ -s pot.diff ]; then - echo "POT file updated" - echo "pot_updated=true" >> $GITHUB_OUTPUT - else - echo "POT file unchanged" - echo "pot_updated=false" >> $GITHUB_OUTPUT - fi - - - name: Push updated POT file - # run only when the POT file has been updated - if: steps.check_changes.outputs.pot_updated == 'true' - run: | - cd agama-weblate - git add web/agama.pot - git commit -m "Update POT file"$'\n\n'"Agama commit: $GITHUB_SHA" - git push