Only run slow CI checks for actual code changes (#3750)
authorNutomic <me@nutomic.com>
Fri, 28 Jul 2023 13:33:23 +0000 (15:33 +0200)
committerGitHub <noreply@github.com>
Fri, 28 Jul 2023 13:33:23 +0000 (09:33 -0400)
* Only run slow CI checks for actual code changes

Its a waste of time to compile Rust and run tests when only
something like the readme was changed.

* also make cache restore/rebuild conditional

* remove unused condition

.woodpecker.yml

index 58ab2f0f947430d8a3b3602b32855024d4ca311c..6353da5cfeb1937f03357d97001de4fd57bf0f95 100644 (file)
@@ -48,6 +48,8 @@ pipeline:
         - "api_tests/node_modules"
     secrets:
       [MINIO_ENDPOINT, MINIO_WRITE_USER, MINIO_WRITE_PASSWORD, MINIO_BUCKET]
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations", "api_tests"]
 
   toml_fmt:
     image: tamasfe/taplo:0.8.1
@@ -65,8 +67,6 @@ pipeline:
       - rustup toolchain install nightly-2023-07-10
       - rustup component add rustfmt --toolchain nightly-2023-07-10
       - cargo +nightly-2023-07-10 fmt -- --check
-    # when:
-    #   platform: linux/amd64
 
   # make sure api builds with default features (used by other crates relying on lemmy api)
   check_api_common_default_features:
@@ -75,8 +75,8 @@ pipeline:
       CARGO_HOME: .cargo
     commands:
       - cargo check --package lemmy_api_common
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   lemmy_api_common_doesnt_depend_on_diesel:
     image: *muslrust_image
@@ -84,8 +84,8 @@ pipeline:
       CARGO_HOME: .cargo
     commands:
       - "! cargo tree -p lemmy_api_common --no-default-features -i diesel"
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   lemmy_api_common_works_with_wasm:
     image: *muslrust_image
@@ -94,6 +94,8 @@ pipeline:
     commands:
       - "rustup target add wasm32-unknown-unknown"
       - "cargo check --target wasm32-unknown-unknown -p lemmy_api_common"
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   check_defaults_hjson_updated:
     image: *muslrust_image
@@ -103,8 +105,8 @@ pipeline:
       - export LEMMY_CONFIG_LOCATION=./config/config.hjson
       - ./scripts/update_config_defaults.sh config/defaults_current.hjson
       - diff config/defaults.hjson config/defaults_current.hjson
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   check_diesel_schema:
     image: willsquire/diesel-cli
@@ -115,6 +117,8 @@ pipeline:
       - diesel migration run
       - diesel print-schema --config-file=diesel.toml > tmp.schema
       - diff tmp.schema crates/db_schema/src/schema.rs
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   check_diesel_migration_revertable:
     image: willsquire/diesel-cli
@@ -124,6 +128,8 @@ pipeline:
     commands:
       - diesel migration run
       - diesel migration redo
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   cargo_clippy:
     image: *muslrust_image
@@ -147,8 +153,8 @@ pipeline:
         -D clippy::needless_collect
         -D clippy::unwrap_used
         -D clippy::indexing_slicing
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   cargo_test:
     image: *muslrust_image
@@ -159,8 +165,8 @@ pipeline:
     commands:
       - export LEMMY_CONFIG_LOCATION=../../config/config.hjson
       - cargo test --workspace --no-fail-fast
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations"]
 
   cargo_build:
     image: *muslrust_image
@@ -169,8 +175,8 @@ pipeline:
     commands:
       - cargo build
       - mv target/x86_64-unknown-linux-musl/debug/lemmy_server target/lemmy_server
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations", "api_tests"]
 
   run_federation_tests:
     image: node:alpine
@@ -183,8 +189,8 @@ pipeline:
       - cd api_tests/
       - yarn
       - yarn api-test
-    when:
-    #   platform: linux/amd64
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations", "api_tests"]
 
   rebuild-cache:
     image: meltwater/drone-cache:v1
@@ -208,6 +214,8 @@ pipeline:
         - "api_tests/node_modules"
     secrets:
       [MINIO_ENDPOINT, MINIO_WRITE_USER, MINIO_WRITE_PASSWORD, MINIO_BUCKET]
+    when:
+      path: ["crates", "src", "Cargo.toml", "migrations", "api_tests"]
 
   publish_release_docker:
     image: woodpeckerci/plugin-docker-buildx
@@ -257,5 +265,3 @@ services:
     environment:
       POSTGRES_USER: lemmy
       POSTGRES_PASSWORD: password
-    # when:
-    #   platform: linux/amd64