The exercises currently target Elixir versions from 1.11 to 1.16 and Erlang/OTP versions from 21 to 26. Detailed installation instructions can be found at https://elixir-lang.org/install.html. We recommend using the asdf version manager to manage multiple Elixir versions.
It is recommended to test BEFORE submitting a PR. It will test your submission, ensure that the repository builds as a whole, and help guard against unintentional, unrelated changes.
To test all of the exercises against their example solution, you can run bin/test_exercises.sh
:
$ ./bin/test_exercises.sh
Testing: accumulate Pass
Testing: acronym Pass
...
Testing: zipper Pass
--------------------------------------------------------------------------------
93/93 tests passed.
This will take some time.
To only test some exercises, run:
$ ./bin/test_exercises.sh word-count zebra-puzzle
Testing: word-count Pass
Testing: zebra-puzzle Pass
--------------------------------------------------------------------------------
2/2 tests passed.
To run dialyzer on all exercises, run ./bin/dialyzer_check.sh
. It might take a really long time the first time you run it. It will also be run for you by Github Actions as part of the PR check.
To check formatting of all exercises and all documents, run ./bin/check_formatting.sh
. It will also be run for you by Github Actions as part of the PR check.
configlet
is an Exercism-wide tool for working with tracks. You can download it by running:
$ ./bin/fetch-configlet
Run its lint
command to verify if all exercises have all the necessary files and if config files are correct:
$ ./bin/configlet lint
The `exercises.practice.slug` value is `transpose 🙂`, but it must be a lowercase and kebab-case string:
/Users/angelika/Documents/exercism/elixir/config.json
Configlet detected at least one problem.
For more information on resolving the problems, please see the documentation:
https://github.com/exercism/docs/blob/main/building/configlet/lint.md
If you want to help maintain the Elixir track, take a look at HELLO.md. You will find there an introduction to all the possible ways you can help us.
If you want to contribute to this repository specifically, please see CONTRIBUTING.md.