-
-
Notifications
You must be signed in to change notification settings - Fork 11
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
Make tests use local version of exercism_test_runner. Closes #51 #52
base: main
Are you sure you want to change the base?
Conversation
Previously the tests had a hard-coded version of `exercism_test_runner`. This is not ideal because the CI tests are not actually testing the code in the repo---it is instead testing a previous version. There are a few pieces to this changeset. 1) The `exercism_test_runner` path is made local and relative in all of the `gleam.toml` files in the `tests` directory. 2) The `gleam_stdlib` versions are updated in those `gleam.toml` files to be consistent with the version used by the local `exercism_test_runner`. 3) An extra mount point is added in the Docker command that runs the tests so that the tests have access to the local version of `exercism_test_runner`.
There's a one things that bothers me about this PR and on which I'd appreciate feedback. I'm using [dependencies]
gleam_stdlib = "~> 0.33 or ~> 1.0" which I saw used elsewhere in this repo but seems weird to me. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe a silly question, but how is the exercism_test_runner
package published?
I don't know. But there's a GitHub Actions workflow in this repo that looks like it deploys to dockerhub. I didn't notice anything deploying to hex. |
The deploy pushes the docker image, not the package. The reason I'm asking is because if the package is published somewhere else, it would be better to do use the package from hex and not locally, as that better simulates the runtime behavior. |
That would be surprising to me; however, I must admit I don't know how exercism is wired together. My naive intuition is that one would test the runtime behavior in exercism/gleam. You can see there, for example, which versions of this package are used in the solutions and such. |
Well, I built the deploy workflow so 😄 The Dockerfile has: # Download the used Gleam packages eagerly as the test runner will not have
# network access to do so. They are also pre-compiled for performance when
# compiling test projects.
RUN cd packages \
&& gleam deps download \
&& gleam build The name = "packages"
version = "0.1.0"
[dependencies]
gleam_bitwise = "~> 1.2"
gleam_otp = "~> 0.7 or ~> 1.0"
gleam_stdlib = "~> 0.32 or ~> 1.0"
simplifile = "~> 1.0"
[dev-dependencies]
exercism_test_runner = "~> 1.4" That seems to confirm what I asserted before. I think the only question is: how does the test runner get published? Maybe this is some manual action? @lpil could you explain how this works? |
Hello! Yes the test runner is published to Hex using the I believe the goal here is to use these tests to test any changes to the test runner itself, but we also need to make sure that they continue to be run with the published version, as this is the one that will actually be used on Exercism. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Then I'll approve!
Previously the tests had a hard-coded version of
exercism_test_runner
. This is not ideal because the CI tests are not actually testing the code in the repo---it is instead testing a previous version.There are a few pieces to this changeset.
The
exercism_test_runner
path is made local and relative in all of thegleam.toml
files in thetests
directory.The
gleam_stdlib
versions are updated in thosegleam.toml
files to be consistent with the version used by the localexercism_test_runner
.An extra mount point is added in the Docker command that runs the tests so that the tests have access to the local version of
exercism_test_runner
.