From 3e25465a585ae6ee9862975681451f5314a264d7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 27 Nov 2023 15:41:07 +0100 Subject: [PATCH 1/7] Implemented unified pipeline template --- .circleci/bundle_ruby_3_0.sh | 4 + .circleci/bundle_ruby_3_2.sh | 3 + .circleci/config.yml | 306 +++++++++++++++------------------ .circleci/config_old.yml | 210 ++++++++++++++++++++++ .circleci/tests_database_ci.sh | 10 ++ 5 files changed, 366 insertions(+), 167 deletions(-) create mode 100644 .circleci/bundle_ruby_3_0.sh create mode 100644 .circleci/bundle_ruby_3_2.sh create mode 100644 .circleci/config_old.yml create mode 100644 .circleci/tests_database_ci.sh diff --git a/.circleci/bundle_ruby_3_0.sh b/.circleci/bundle_ruby_3_0.sh new file mode 100644 index 0000000000..15d0dfcbd4 --- /dev/null +++ b/.circleci/bundle_ruby_3_0.sh @@ -0,0 +1,4 @@ +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B +sudo apt-get update && sudo apt-get install libvips +bundle config --local path vendor/bundle +bundle check || bundle install \ No newline at end of file diff --git a/.circleci/bundle_ruby_3_2.sh b/.circleci/bundle_ruby_3_2.sh new file mode 100644 index 0000000000..2539cdeb07 --- /dev/null +++ b/.circleci/bundle_ruby_3_2.sh @@ -0,0 +1,3 @@ +sudo apt-get update && sudo apt-get install libvips42 +bundle config --local path vendor/bundle +bundle check || bundle install \ No newline at end of file diff --git a/.circleci/config.yml b/.circleci/config.yml index 885969ab06..7ad8941eca 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -1,186 +1,107 @@ version: 2.1 defaults: &defaults + parameters: &default_parameters + ruby_image: + type: string + redis_image: + type: string + restore_cache_key_1: + type: string + default: 'spree-bundle-v10-ruby-3-2-{{ .Branch }}' + restore_cache_key_2: + type: string + default: spree-bundle-v10-ruby-3-2 + save_cache_key: + type: string + default: "n" + run_file_path: + type: string + rails_version: + type: string + default: '~> 7.0.0' + store_artefacts: + type: boolean + default: false environment: &environment - CIRCLE_TEST_REPORTS: /tmp/test-results - CIRCLE_ARTIFACTS: /tmp/test-artifacts - BUNDLE_JOBS: 4 - BUNDLE_RETRY: 3 - BUNDLE_PATH: ~/spree/vendor/bundle - RAILS_VERSION: '~> 7.1.0' + CIRCLE_TEST_REPORTS: /tmp/test-results + CIRCLE_ARTIFACTS: /tmp/test-artifacts + BUNDLE_JOBS: 4 + BUNDLE_RETRY: 3 + BUNDLE_PATH: ~/spree/vendor/bundle + RAILS_VERSION: << parameters.rails_version >> working_directory: ~/spree docker: - - image: &ruby_3_0_image circleci/ruby:3.0-node-browsers - - image: &redis_image circleci/redis:6.2-alpine + - image: &ruby_image << parameters.ruby_image >> + - image: &redis_image << parameters.redis_image >> -defaults_3_2: &defaults_3_2 - <<: *defaults - docker: - - image: &ruby_3_2_image cimg/ruby:3.2.0-browsers - - image: *redis_image - -run_tests_3_0: &run_tests_3_0 - <<: *defaults - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 - - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts - -run_tests_3_2: &run_tests_3_2 - <<: *defaults_3_2 - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts jobs: - bundle_ruby_3_0: + run_test: &run_test <<: *defaults - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 - - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} - - bundle_ruby_3_2: - <<: *defaults_3_2 - steps: + steps: &default_steps - checkout - restore_cache: keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 + - << parameters.restore_cache_key_1 >> + - << parameters.restore_cache_key_2 >> - run: - name: Set bundle path - command: bundle config --local path vendor/bundle + name: Allow executing given file + command: chmod +x << parameters.run_file_path >> - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} + name: Run << parameters.run_file_path >> file + command: bash << parameters.run_file_path >> + - when: + condition: << parameters.save_cache_key >> + steps: + - save_cache: + key: << parameters.save_cache_key >> + paths: + - ~/spree/vendor/bundle + - when: + condition: << parameters.store_artefacts >> + steps: + - store_artifacts: + path: /tmp/test-artifacts + destination: test-artifacts + - store_artifacts: + path: /tmp/test-results + destination: raw-test-output + - store_test_results: + path: /tmp/test-results - tests_ruby_3_0_rails_7_0_postgres: - <<: *run_tests_3_0 + tests_postgres: + <<: *run_test + parallelism: << parameters.parallelism >> + parameters: + <<: *default_parameters + postgres_image: + type: string + parallelism: + type: integer + default: 3 environment: <<: *environment DB: postgres DB_HOST: localhost DB_USERNAME: postgres - RAILS_VERSION: '~> 7.0.0' docker: - - image: *ruby_3_0_image - - image: &postgres_image circleci/postgres:12-alpine + - image: *ruby_image + - image: << parameters.postgres_image >> environment: POSTGRES_USER: postgres - image: *redis_image - tests_ruby_3_2_rails_7_1_postgres: - <<: *run_tests_3_2 - environment: - <<: *environment - DB: postgres - DB_HOST: localhost - DB_USERNAME: postgres - docker: - - image: *ruby_3_2_image - - image: *postgres_image - - image: *redis_image - - tests_ruby_3_2_rails_7_1_mysql: - <<: *run_tests_3_2 + tests_mysql: + <<: *run_test + parallelism: << parameters.parallelism >> + parameters: + <<: *default_parameters + mysql_image: + type: string + parallelism: + type: integer + default: 3 environment: <<: *environment DB: mysql @@ -189,22 +110,73 @@ jobs: COVERAGE: true COVERAGE_DIR: /tmp/workspace/simplecov docker: - - image: *ruby_3_2_image + - image: *ruby_image - image: *redis_image - - image: &mysql_image circleci/mysql:8-ram + - image: << parameters.mysql_image >> + command: [--default-authentication-plugin=mysql_native_password] + + send_test_coverage: + <<: *defaults + steps: + - checkout + - attach_workspace: + at: /tmp/workspace + - run: + name: Allow executing given file + command: chmod +x << parameters.run_file_path >> + - run: + name: Send test coverage + command: bash << parameters.run_file_path >> + workflows: version: 2 main: jobs: - - bundle_ruby_3_0 - - bundle_ruby_3_2 - - tests_ruby_3_2_rails_7_1_postgres: + - run_test: + name: bundle_ruby_3_0 + restore_cache_key_1: "spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }}" + restore_cache_key_2: "spree-dashboard-bundle-v10-ruby-3-0" + ruby_image: circleci/ruby:3.0-node-browsers + redis_image: circleci/redis:6.2-alpine + run_file_path: ./.circleci/bundle_ruby_3_0.sh + save_cache_key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} + - run_test: + name: bundle_ruby_3_2 + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + run_file_path: ./.circleci/bundle_ruby_3_2.sh + save_cache_key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} + - tests_postgres: + name: tests_ruby_3_2_rails_7_1_postgres + parallelism: 8 + rails_version: '~> 7.1.0' + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + postgres_image: circleci/postgres:12-alpine + store_artefacts: true + run_file_path: ./.circleci/tests_database_ci.sh requires: - - bundle_ruby_3_2 - - tests_ruby_3_0_rails_7_0_postgres: + - bundle_ruby_3_2 + - tests_postgres: + name: tests_ruby_3_0_rails_7_0_postgres + parallelism: 8 + rails_version: '~> 7.0.0' + ruby_image: circleci/ruby:3.0-node-browsers + redis_image: circleci/redis:6.2-alpine + postgres_image: circleci/postgres:12-alpine + store_artefacts: true + run_file_path: ./.circleci/tests_database_ci.sh requires: - - bundle_ruby_3_0 - - tests_ruby_3_2_rails_7_1_mysql: + - bundle_ruby_3_0 + - tests_mysql: + name: tests_ruby_3_2_rails_7_1_mysql + rails_version: '~> 7.1.0' + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + mysql_image: circleci/mysql:8-ram + store_artefacts: true + run_file_path: ./bin/tests_database_ci.sh requires: - - bundle_ruby_3_2 + - bundle_ruby_3_2 + diff --git a/.circleci/config_old.yml b/.circleci/config_old.yml new file mode 100644 index 0000000000..885969ab06 --- /dev/null +++ b/.circleci/config_old.yml @@ -0,0 +1,210 @@ +version: 2.1 + +defaults: &defaults + environment: &environment + CIRCLE_TEST_REPORTS: /tmp/test-results + CIRCLE_ARTIFACTS: /tmp/test-artifacts + BUNDLE_JOBS: 4 + BUNDLE_RETRY: 3 + BUNDLE_PATH: ~/spree/vendor/bundle + RAILS_VERSION: '~> 7.1.0' + working_directory: ~/spree + docker: + - image: &ruby_3_0_image circleci/ruby:3.0-node-browsers + - image: &redis_image circleci/redis:6.2-alpine + +defaults_3_2: &defaults_3_2 + <<: *defaults + docker: + - image: &ruby_3_2_image cimg/ruby:3.2.0-browsers + - image: *redis_image + +run_tests_3_0: &run_tests_3_0 + <<: *defaults + parallelism: 8 + steps: + - checkout + - restore_cache: + keys: + - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} + - spree-dashboard-bundle-v10-ruby-3-0 + - run: + name: Add keyserver + command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B + - run: + name: Install libvips + command: sudo apt-get update && sudo apt-get install libvips + - run: + name: Set bundle path + command: bundle config --local path vendor/bundle + - run: + name: Ensure bundle Install + command: | + bundle check || bundle install + - run: + name: Create test app + command: | + bundle exec rake test_app + - run: + name: Unlink NPM package + command: | + cd spec/dummy && yarn unlink @spree/dashboard + - run: + name: Run Rspec + command: | + TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) + bundle exec rspec --format documentation \ + --format RspecJunitFormatter \ + -o ~/rspec/rspec.xml \ + -- ${TESTFILES} + - store_test_results: + path: ~/rspec + - store_artifacts: + path: /tmp/test-artifacts + +run_tests_3_2: &run_tests_3_2 + <<: *defaults_3_2 + parallelism: 8 + steps: + - checkout + - restore_cache: + keys: + - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} + - spree-dashboard-bundle-v10-ruby-3-2 + - run: + name: Install libvips + command: sudo apt-get update && sudo apt-get install libvips42 + - run: + name: Set bundle path + command: bundle config --local path vendor/bundle + - run: + name: Ensure bundle Install + command: | + bundle check || bundle install + - run: + name: Create test app + command: | + bundle exec rake test_app + - run: + name: Unlink NPM package + command: | + cd spec/dummy && yarn unlink @spree/dashboard + - run: + name: Run Rspec + command: | + TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) + bundle exec rspec --format documentation \ + --format RspecJunitFormatter \ + -o ~/rspec/rspec.xml \ + -- ${TESTFILES} + - store_test_results: + path: ~/rspec + - store_artifacts: + path: /tmp/test-artifacts + +jobs: + bundle_ruby_3_0: + <<: *defaults + steps: + - checkout + - restore_cache: + keys: + - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} + - spree-dashboard-bundle-v10-ruby-3-0 + - run: + name: Add keyserver + command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B + - run: + name: Install libvips + command: sudo apt-get update && sudo apt-get install libvips + - run: + name: Set bundle path + command: bundle config --local path vendor/bundle + - run: + name: Bundle Install + command: | + bundle check || bundle install + - save_cache: + paths: + - vendor/bundle + key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} + + bundle_ruby_3_2: + <<: *defaults_3_2 + steps: + - checkout + - restore_cache: + keys: + - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} + - spree-dashboard-bundle-v10-ruby-3-2 + - run: + name: Install libvips + command: sudo apt-get update && sudo apt-get install libvips42 + - run: + name: Set bundle path + command: bundle config --local path vendor/bundle + - run: + name: Bundle Install + command: | + bundle check || bundle install + - save_cache: + paths: + - vendor/bundle + key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} + + tests_ruby_3_0_rails_7_0_postgres: + <<: *run_tests_3_0 + environment: + <<: *environment + DB: postgres + DB_HOST: localhost + DB_USERNAME: postgres + RAILS_VERSION: '~> 7.0.0' + docker: + - image: *ruby_3_0_image + - image: &postgres_image circleci/postgres:12-alpine + environment: + POSTGRES_USER: postgres + - image: *redis_image + + tests_ruby_3_2_rails_7_1_postgres: + <<: *run_tests_3_2 + environment: + <<: *environment + DB: postgres + DB_HOST: localhost + DB_USERNAME: postgres + docker: + - image: *ruby_3_2_image + - image: *postgres_image + - image: *redis_image + + tests_ruby_3_2_rails_7_1_mysql: + <<: *run_tests_3_2 + environment: + <<: *environment + DB: mysql + DB_HOST: 127.0.0.1 + DB_USERNAME: root + COVERAGE: true + COVERAGE_DIR: /tmp/workspace/simplecov + docker: + - image: *ruby_3_2_image + - image: *redis_image + - image: &mysql_image circleci/mysql:8-ram + +workflows: + version: 2 + main: + jobs: + - bundle_ruby_3_0 + - bundle_ruby_3_2 + - tests_ruby_3_2_rails_7_1_postgres: + requires: + - bundle_ruby_3_2 + - tests_ruby_3_0_rails_7_0_postgres: + requires: + - bundle_ruby_3_0 + - tests_ruby_3_2_rails_7_1_mysql: + requires: + - bundle_ruby_3_2 diff --git a/.circleci/tests_database_ci.sh b/.circleci/tests_database_ci.sh new file mode 100644 index 0000000000..4b43da5e92 --- /dev/null +++ b/.circleci/tests_database_ci.sh @@ -0,0 +1,10 @@ +sudo apt-get update && sudo apt-get install libvips42 +bundle config --local path vendor/bundle +bundle check || bundle install +bundle exec rake test_app +cd spec/dummy && yarn unlink @spree/dashboard +TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) + bundle exec rspec --format documentation \ + --format RspecJunitFormatter \ + -o ~/rspec/rspec.xml \ + -- ${TESTFILES} \ No newline at end of file From 22f5760833a9142a750a3e5fe540435b97866b7d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 27 Nov 2023 15:52:20 +0100 Subject: [PATCH 2/7] bug fix, deleted old verision of config.yml file --- .circleci/config.yml | 2 +- .circleci/config_old.yml | 210 --------------------------------------- 2 files changed, 1 insertion(+), 211 deletions(-) delete mode 100644 .circleci/config_old.yml diff --git a/.circleci/config.yml b/.circleci/config.yml index 7ad8941eca..ee6fb92cdd 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -176,7 +176,7 @@ workflows: redis_image: circleci/redis:6.2-alpine mysql_image: circleci/mysql:8-ram store_artefacts: true - run_file_path: ./bin/tests_database_ci.sh + run_file_path: ./.circleci/tests_database_ci.sh requires: - bundle_ruby_3_2 diff --git a/.circleci/config_old.yml b/.circleci/config_old.yml deleted file mode 100644 index 885969ab06..0000000000 --- a/.circleci/config_old.yml +++ /dev/null @@ -1,210 +0,0 @@ -version: 2.1 - -defaults: &defaults - environment: &environment - CIRCLE_TEST_REPORTS: /tmp/test-results - CIRCLE_ARTIFACTS: /tmp/test-artifacts - BUNDLE_JOBS: 4 - BUNDLE_RETRY: 3 - BUNDLE_PATH: ~/spree/vendor/bundle - RAILS_VERSION: '~> 7.1.0' - working_directory: ~/spree - docker: - - image: &ruby_3_0_image circleci/ruby:3.0-node-browsers - - image: &redis_image circleci/redis:6.2-alpine - -defaults_3_2: &defaults_3_2 - <<: *defaults - docker: - - image: &ruby_3_2_image cimg/ruby:3.2.0-browsers - - image: *redis_image - -run_tests_3_0: &run_tests_3_0 - <<: *defaults - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 - - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts - -run_tests_3_2: &run_tests_3_2 - <<: *defaults_3_2 - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts - -jobs: - bundle_ruby_3_0: - <<: *defaults - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 - - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} - - bundle_ruby_3_2: - <<: *defaults_3_2 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} - - tests_ruby_3_0_rails_7_0_postgres: - <<: *run_tests_3_0 - environment: - <<: *environment - DB: postgres - DB_HOST: localhost - DB_USERNAME: postgres - RAILS_VERSION: '~> 7.0.0' - docker: - - image: *ruby_3_0_image - - image: &postgres_image circleci/postgres:12-alpine - environment: - POSTGRES_USER: postgres - - image: *redis_image - - tests_ruby_3_2_rails_7_1_postgres: - <<: *run_tests_3_2 - environment: - <<: *environment - DB: postgres - DB_HOST: localhost - DB_USERNAME: postgres - docker: - - image: *ruby_3_2_image - - image: *postgres_image - - image: *redis_image - - tests_ruby_3_2_rails_7_1_mysql: - <<: *run_tests_3_2 - environment: - <<: *environment - DB: mysql - DB_HOST: 127.0.0.1 - DB_USERNAME: root - COVERAGE: true - COVERAGE_DIR: /tmp/workspace/simplecov - docker: - - image: *ruby_3_2_image - - image: *redis_image - - image: &mysql_image circleci/mysql:8-ram - -workflows: - version: 2 - main: - jobs: - - bundle_ruby_3_0 - - bundle_ruby_3_2 - - tests_ruby_3_2_rails_7_1_postgres: - requires: - - bundle_ruby_3_2 - - tests_ruby_3_0_rails_7_0_postgres: - requires: - - bundle_ruby_3_0 - - tests_ruby_3_2_rails_7_1_mysql: - requires: - - bundle_ruby_3_2 From e849467203a4ff77c66d8e9ed19b15a5f2c0c283 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 27 Nov 2023 16:36:57 +0100 Subject: [PATCH 3/7] Fixed issue with storing tests results --- .circleci/config.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index ee6fb92cdd..cf7fd67a4a 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -68,7 +68,7 @@ jobs: path: /tmp/test-results destination: raw-test-output - store_test_results: - path: /tmp/test-results + path: ~/rspec tests_postgres: <<: *run_test From ffe8201e87f1000b5eb4eb5e0859706f0bec4004 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 27 Nov 2023 15:41:07 +0100 Subject: [PATCH 4/7] Implemented unified pipeline template --- .circleci/config.yml | 306 ++++++++++++++++++--------------------- bin/bundle_ruby.sh | 3 + bin/bundle_ruby_3_0.sh | 4 + bin/tests_database_ci.sh | 10 ++ 4 files changed, 156 insertions(+), 167 deletions(-) create mode 100644 bin/bundle_ruby.sh create mode 100644 bin/bundle_ruby_3_0.sh create mode 100644 bin/tests_database_ci.sh diff --git a/.circleci/config.yml b/.circleci/config.yml index 885969ab06..de60bdd97d 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -1,186 +1,107 @@ version: 2.1 defaults: &defaults + parameters: &default_parameters + ruby_image: + type: string + redis_image: + type: string + restore_cache_key_1: + type: string + default: 'spree-bundle-v10-ruby-3-2-{{ .Branch }}' + restore_cache_key_2: + type: string + default: spree-bundle-v10-ruby-3-2 + save_cache_key: + type: string + default: "n" + run_file_path: + type: string + rails_version: + type: string + default: '~> 7.0.0' + store_artefacts: + type: boolean + default: false environment: &environment - CIRCLE_TEST_REPORTS: /tmp/test-results - CIRCLE_ARTIFACTS: /tmp/test-artifacts - BUNDLE_JOBS: 4 - BUNDLE_RETRY: 3 - BUNDLE_PATH: ~/spree/vendor/bundle - RAILS_VERSION: '~> 7.1.0' + CIRCLE_TEST_REPORTS: /tmp/test-results + CIRCLE_ARTIFACTS: /tmp/test-artifacts + BUNDLE_JOBS: 4 + BUNDLE_RETRY: 3 + BUNDLE_PATH: ~/spree/vendor/bundle + RAILS_VERSION: << parameters.rails_version >> working_directory: ~/spree docker: - - image: &ruby_3_0_image circleci/ruby:3.0-node-browsers - - image: &redis_image circleci/redis:6.2-alpine + - image: &ruby_image << parameters.ruby_image >> + - image: &redis_image << parameters.redis_image >> -defaults_3_2: &defaults_3_2 - <<: *defaults - docker: - - image: &ruby_3_2_image cimg/ruby:3.2.0-browsers - - image: *redis_image - -run_tests_3_0: &run_tests_3_0 - <<: *defaults - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 - - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts - -run_tests_3_2: &run_tests_3_2 - <<: *defaults_3_2 - parallelism: 8 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Ensure bundle Install - command: | - bundle check || bundle install - - run: - name: Create test app - command: | - bundle exec rake test_app - - run: - name: Unlink NPM package - command: | - cd spec/dummy && yarn unlink @spree/dashboard - - run: - name: Run Rspec - command: | - TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} - - store_test_results: - path: ~/rspec - - store_artifacts: - path: /tmp/test-artifacts jobs: - bundle_ruby_3_0: + run_test: &run_test <<: *defaults - steps: + steps: &default_steps - checkout - restore_cache: keys: - - spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-0 + - << parameters.restore_cache_key_1 >> + - << parameters.restore_cache_key_2 >> - run: - name: Add keyserver - command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B + name: Allow executing given file + command: chmod +x << parameters.run_file_path >> - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} + name: Run << parameters.run_file_path >> file + command: bash << parameters.run_file_path >> + - when: + condition: << parameters.save_cache_key >> + steps: + - save_cache: + key: << parameters.save_cache_key >> + paths: + - ~/spree/vendor/bundle + - when: + condition: << parameters.store_artefacts >> + steps: + - store_artifacts: + path: /tmp/test-artifacts + destination: test-artifacts + - store_artifacts: + path: /tmp/test-results + destination: raw-test-output + - store_test_results: + path: ~/rspec - bundle_ruby_3_2: - <<: *defaults_3_2 - steps: - - checkout - - restore_cache: - keys: - - spree-dashboard-bundle-v10-ruby-3-2-{{ .Branch }} - - spree-dashboard-bundle-v10-ruby-3-2 - - run: - name: Install libvips - command: sudo apt-get update && sudo apt-get install libvips42 - - run: - name: Set bundle path - command: bundle config --local path vendor/bundle - - run: - name: Bundle Install - command: | - bundle check || bundle install - - save_cache: - paths: - - vendor/bundle - key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} - - tests_ruby_3_0_rails_7_0_postgres: - <<: *run_tests_3_0 + tests_postgres: + <<: *run_test + parallelism: << parameters.parallelism >> + parameters: + <<: *default_parameters + postgres_image: + type: string + parallelism: + type: integer + default: 3 environment: <<: *environment DB: postgres DB_HOST: localhost DB_USERNAME: postgres - RAILS_VERSION: '~> 7.0.0' docker: - - image: *ruby_3_0_image - - image: &postgres_image circleci/postgres:12-alpine + - image: *ruby_image + - image: << parameters.postgres_image >> environment: POSTGRES_USER: postgres - image: *redis_image - tests_ruby_3_2_rails_7_1_postgres: - <<: *run_tests_3_2 - environment: - <<: *environment - DB: postgres - DB_HOST: localhost - DB_USERNAME: postgres - docker: - - image: *ruby_3_2_image - - image: *postgres_image - - image: *redis_image - - tests_ruby_3_2_rails_7_1_mysql: - <<: *run_tests_3_2 + tests_mysql: + <<: *run_test + parallelism: << parameters.parallelism >> + parameters: + <<: *default_parameters + mysql_image: + type: string + parallelism: + type: integer + default: 3 environment: <<: *environment DB: mysql @@ -189,22 +110,73 @@ jobs: COVERAGE: true COVERAGE_DIR: /tmp/workspace/simplecov docker: - - image: *ruby_3_2_image + - image: *ruby_image - image: *redis_image - - image: &mysql_image circleci/mysql:8-ram + - image: << parameters.mysql_image >> + command: [--default-authentication-plugin=mysql_native_password] + + send_test_coverage: + <<: *defaults + steps: + - checkout + - attach_workspace: + at: /tmp/workspace + - run: + name: Allow executing given file + command: chmod +x << parameters.run_file_path >> + - run: + name: Send test coverage + command: bash << parameters.run_file_path >> + workflows: version: 2 main: jobs: - - bundle_ruby_3_0 - - bundle_ruby_3_2 - - tests_ruby_3_2_rails_7_1_postgres: + - run_test: + name: bundle_ruby_3_0 + restore_cache_key_1: "spree-dashboard-bundle-v10-ruby-3-0-{{ .Branch }}" + restore_cache_key_2: "spree-dashboard-bundle-v10-ruby-3-0" + ruby_image: circleci/ruby:3.0-node-browsers + redis_image: circleci/redis:6.2-alpine + run_file_path: ./bin/bundle_ruby_3_0.sh + save_cache_key: spree-dashboard-bundle-v10-ruby-3-0-{{ checksum "Gemfile.lock" }} + - run_test: + name: bundle_ruby_3_2 + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + run_file_path: ./bin/bundle_ruby.sh + save_cache_key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} + - tests_postgres: + name: tests_ruby_3_2_rails_7_1_postgres + parallelism: 8 + rails_version: '~> 7.1.0' + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + postgres_image: circleci/postgres:12-alpine + store_artefacts: true + run_file_path: ./bin/tests_database_ci.sh requires: - - bundle_ruby_3_2 - - tests_ruby_3_0_rails_7_0_postgres: + - bundle_ruby_3_2 + - tests_postgres: + name: tests_ruby_3_0_rails_7_0_postgres + parallelism: 8 + rails_version: '~> 7.0.0' + ruby_image: circleci/ruby:3.0-node-browsers + redis_image: circleci/redis:6.2-alpine + postgres_image: circleci/postgres:12-alpine + store_artefacts: true + run_file_path: ./bin/tests_database_ci.sh requires: - - bundle_ruby_3_0 - - tests_ruby_3_2_rails_7_1_mysql: + - bundle_ruby_3_0 + - tests_mysql: + name: tests_ruby_3_2_rails_7_1_mysql + rails_version: '~> 7.1.0' + ruby_image: cimg/ruby:3.2.0-browsers + redis_image: circleci/redis:6.2-alpine + mysql_image: circleci/mysql:8-ram + store_artefacts: true + run_file_path: ./bin/tests_database_ci.sh requires: - - bundle_ruby_3_2 + - bundle_ruby_3_2 + diff --git a/bin/bundle_ruby.sh b/bin/bundle_ruby.sh new file mode 100644 index 0000000000..2539cdeb07 --- /dev/null +++ b/bin/bundle_ruby.sh @@ -0,0 +1,3 @@ +sudo apt-get update && sudo apt-get install libvips42 +bundle config --local path vendor/bundle +bundle check || bundle install \ No newline at end of file diff --git a/bin/bundle_ruby_3_0.sh b/bin/bundle_ruby_3_0.sh new file mode 100644 index 0000000000..15d0dfcbd4 --- /dev/null +++ b/bin/bundle_ruby_3_0.sh @@ -0,0 +1,4 @@ +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B +sudo apt-get update && sudo apt-get install libvips +bundle config --local path vendor/bundle +bundle check || bundle install \ No newline at end of file diff --git a/bin/tests_database_ci.sh b/bin/tests_database_ci.sh new file mode 100644 index 0000000000..4b43da5e92 --- /dev/null +++ b/bin/tests_database_ci.sh @@ -0,0 +1,10 @@ +sudo apt-get update && sudo apt-get install libvips42 +bundle config --local path vendor/bundle +bundle check || bundle install +bundle exec rake test_app +cd spec/dummy && yarn unlink @spree/dashboard +TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) + bundle exec rspec --format documentation \ + --format RspecJunitFormatter \ + -o ~/rspec/rspec.xml \ + -- ${TESTFILES} \ No newline at end of file From 9fc855fa3b857af224333d988a4dfd407f56f8b4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 8 Jan 2024 13:12:50 +0100 Subject: [PATCH 5/7] pipeline test --- .circleci/tests_database_ci.sh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.circleci/tests_database_ci.sh b/.circleci/tests_database_ci.sh index 4b43da5e92..6432acf2ed 100644 --- a/.circleci/tests_database_ci.sh +++ b/.circleci/tests_database_ci.sh @@ -1,3 +1,6 @@ +pwd +cd ../.. +pwd sudo apt-get update && sudo apt-get install libvips42 bundle config --local path vendor/bundle bundle check || bundle install @@ -7,4 +10,4 @@ TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --spl bundle exec rspec --format documentation \ --format RspecJunitFormatter \ -o ~/rspec/rspec.xml \ - -- ${TESTFILES} \ No newline at end of file + -- ${TESTFILES} From 59321c1ef68234cfbcb682884df1377dbc4d6e1a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 8 Jan 2024 13:33:46 +0100 Subject: [PATCH 6/7] Tests properly running on CircleCI --- .circleci/bundle_ruby_3_0.sh | 4 ---- .circleci/bundle_ruby_3_2.sh | 3 --- .circleci/tests_database_ci.sh | 13 ------------- bin/tests_database_ci.sh | 4 ++-- 4 files changed, 2 insertions(+), 22 deletions(-) delete mode 100644 .circleci/bundle_ruby_3_0.sh delete mode 100644 .circleci/bundle_ruby_3_2.sh delete mode 100644 .circleci/tests_database_ci.sh diff --git a/.circleci/bundle_ruby_3_0.sh b/.circleci/bundle_ruby_3_0.sh deleted file mode 100644 index 15d0dfcbd4..0000000000 --- a/.circleci/bundle_ruby_3_0.sh +++ /dev/null @@ -1,4 +0,0 @@ -sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4EB27DB2A3B88B8B -sudo apt-get update && sudo apt-get install libvips -bundle config --local path vendor/bundle -bundle check || bundle install \ No newline at end of file diff --git a/.circleci/bundle_ruby_3_2.sh b/.circleci/bundle_ruby_3_2.sh deleted file mode 100644 index 2539cdeb07..0000000000 --- a/.circleci/bundle_ruby_3_2.sh +++ /dev/null @@ -1,3 +0,0 @@ -sudo apt-get update && sudo apt-get install libvips42 -bundle config --local path vendor/bundle -bundle check || bundle install \ No newline at end of file diff --git a/.circleci/tests_database_ci.sh b/.circleci/tests_database_ci.sh deleted file mode 100644 index 6432acf2ed..0000000000 --- a/.circleci/tests_database_ci.sh +++ /dev/null @@ -1,13 +0,0 @@ -pwd -cd ../.. -pwd -sudo apt-get update && sudo apt-get install libvips42 -bundle config --local path vendor/bundle -bundle check || bundle install -bundle exec rake test_app -cd spec/dummy && yarn unlink @spree/dashboard -TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) - bundle exec rspec --format documentation \ - --format RspecJunitFormatter \ - -o ~/rspec/rspec.xml \ - -- ${TESTFILES} diff --git a/bin/tests_database_ci.sh b/bin/tests_database_ci.sh index 4b43da5e92..e5861ba6ae 100644 --- a/bin/tests_database_ci.sh +++ b/bin/tests_database_ci.sh @@ -2,9 +2,9 @@ sudo apt-get update && sudo apt-get install libvips42 bundle config --local path vendor/bundle bundle check || bundle install bundle exec rake test_app -cd spec/dummy && yarn unlink @spree/dashboard +cd spec/dummy && yarn unlink @spree/dashboard && cd ../.. TESTFILES=$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings) bundle exec rspec --format documentation \ --format RspecJunitFormatter \ -o ~/rspec/rspec.xml \ - -- ${TESTFILES} \ No newline at end of file + -- ${TESTFILES} From fb119fc5b30e5cebf9e51c36c2c65df97c72122b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Por=C4=99bski?= Date: Mon, 8 Jan 2024 15:42:50 +0100 Subject: [PATCH 7/7] Tests parallelism is set to 8 by default --- .circleci/config.yml | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index de60bdd97d..2c181d52e0 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -79,7 +79,7 @@ jobs: type: string parallelism: type: integer - default: 3 + default: 8 environment: <<: *environment DB: postgres @@ -101,7 +101,7 @@ jobs: type: string parallelism: type: integer - default: 3 + default: 8 environment: <<: *environment DB: mysql @@ -149,7 +149,6 @@ workflows: save_cache_key: spree-dashboard-bundle-v10-ruby-3-2-{{ checksum "Gemfile.lock" }} - tests_postgres: name: tests_ruby_3_2_rails_7_1_postgres - parallelism: 8 rails_version: '~> 7.1.0' ruby_image: cimg/ruby:3.2.0-browsers redis_image: circleci/redis:6.2-alpine @@ -160,7 +159,6 @@ workflows: - bundle_ruby_3_2 - tests_postgres: name: tests_ruby_3_0_rails_7_0_postgres - parallelism: 8 rails_version: '~> 7.0.0' ruby_image: circleci/ruby:3.0-node-browsers redis_image: circleci/redis:6.2-alpine