Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Only run tests for exercises that have changed #2693

Open
sanderploegsma opened this issue Jan 30, 2024 · 7 comments · May be fixed by #2882
Open

Only run tests for exercises that have changed #2693

sanderploegsma opened this issue Jan 30, 2024 · 7 comments · May be fixed by #2882
Assignees

Comments

@sanderploegsma
Copy link
Contributor

To make the feedback cycle for contributions a lot shorter, it would be great if some of our GitHub Actions workflows would only check exercises that have been updated in the corresponding Pull Request.

Nothing is as annoying as updating a single file and having to wait for almost 10 minutes for the test runner to finish testing every exercise. Not to mention when one of those tests then fails even though you didn't even change anything there!

I'm open to ideas on how to achieve this. If you have a good idea please leave a comment on this issue!

@sanderploegsma sanderploegsma added x:action/improve Improve existing functionality/content x:type/ci Work on Continuous Integration (e.g. GitHub Actions workflows) and removed x:action/improve Improve existing functionality/content x:type/ci Work on Continuous Integration (e.g. GitHub Actions workflows) labels Jan 30, 2024
@josealonso josealonso linked a pull request Dec 28, 2024 that will close this issue
@josealonso
Copy link
Contributor

@sanderploegsma, could you please assign it to me ?
Working on this #2882.
Thanks :)

@kahgoh kahgoh assigned kahgoh and josealonso and unassigned kahgoh Dec 28, 2024
@kahgoh
Copy link
Member

kahgoh commented Dec 28, 2024

I've just assigned this one to you @josealonso

@josealonso
Copy link
Contributor

I've just assigned this one to you @josealonso

Thanks, @kahgoh!!

@josealonso
Copy link
Contributor

I created a Gradle task that detects the changes, but I creating a custom command doesn't work:

 tasks.register('compileChangedModules') {
      dependsOn detectChangedModules
      doLast {
        if (changedModules.isEmpty()) {
          println "No modules to compile."
        } else {
          changedModules.each { module ->
            println "Compiling module: $module"
            exec {
              commandLine "./gradlew", ":$module:compileStarterTestJava"
            }
          }
        }
      }
    }

@josealonso
Copy link
Contributor

This compiles, but calling this task raises an exception in run-time. Could you explain me where the command ./gradlew test is declared, @kahgoh ?

@kahgoh
Copy link
Member

kahgoh commented Jan 3, 2025

@josealonso, gradlew is the Gradle wrapper script added by Gradle and is also checked in with the code. For example, the one for leap is here.

There is also one in the exercises directory of the repo (I think this is one you want to use).

@josealonso
Copy link
Contributor

@josealonso, gradlew is the Gradle wrapper script added by Gradle and is also checked in with the code. For example, the one for leap is here.

There is also one in the exercises directory of the repo (I think this is one you want to use).

I know gradlew is the Gradle wrapper. But I don't understand this issue, because Gradle by default only compiles the modified modules. I will look into it more in-depth. Thanks for your reply :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants