Skip to content

Latest commit

 

History

History
74 lines (48 loc) · 5.36 KB

CONTRIBUTING.md

File metadata and controls

74 lines (48 loc) · 5.36 KB

Contributing to Geni

First and foremost, thank you for taking an interest to contribute to Geni. This project can only improve with your help!

First-time contributor? You are most welcomed! Check out the Open Source Guide!

Contributions

All kinds of contributions are welcomed!

If you would like to report an issue or request a new feature, please create a new issue. If you have a question, please reach out to the Clojurians Slack channel #geni. Finally, to avoid duplication of work, please let us know if you would like to have a crack on the issue by leaving a comment on the issue!

Geni aims to cover as many of Spark's features as possible. If you find a missing feature, please report it as an issue. Ideally it would come with a use case and a link to the original Spark documentation as references.

Geni also aims to be an idiomatic Clojure library. If you have any suggestions on Clojure idioms or metaphors that would apply to Spark, please let us know!

Any help on documentation and tutorials would also be great! Linking the Clojure function with the original Spark documentation can be a great help. Adding any examples or discussion points will improve the getting-started experience of Geni.

Contributing Walkthrough

To contribute to Geni, please fork the main repository and submit a pull request. A maintainer should pick up the pull request and review the changes, which hopefully gets approved and merged to the develop branch!

To make sure that the project builds correctly, clone your forked repository and run make ci (or make ci --jobs 3 on a bigger machine). This should build a docker container, report the test coverage using cloverage, check for linting errors using clj-kondo, check that no artifacts are out of date using lein-ancient, run the unit tests on the lein template, test the installation of the Geni CLI and test the Geni REPL uberjar.

Note that, on macOS, you must allow file sharing for the temporary folders. To do this, go to Docker's Preferences > Resources > File Sharing and add /var/folders/.

If your tests failed, the failure could come from Spark. In this case, it may be helpful to re-run your the tests with a more verbose log level for debugging purposes. Note that the default log level for Spark is INFO, which makes for a very noisy REPL, so Geni opts for WARNING as the default instead. Change the log level to INFO on the default SparkSession by adding the key-value pair {:log-level "INFO"} on the defaults.clj source file.

As much as possible, we would like to keep the test coverage close to (and ideally at) 100%. Much of the actual data work is done by Spark, so it should be sufficient to check that we are calling the right Spark functions and methods. There should also be zero lint errors and warnings.

Once you are happy with the changes, run make ci once again to check that all the CI steps pass. Every pull request will additionally trigger actions to check these conditions.

Development Tools

Geni uses Midje as its test runner. It allows us to do watch and run our unit tests should there be any changes to the source code. Midje is smart enough to load namespaces that are required by the changed file.

Additionally, there are unit tests that are marked as "slow", which may not be relevant if you are working on a new, orthogonal feature or bug fix. To watch and run non-slow tests, we could either run:

lein midje :autotest :filter -slow

or spin up a REPL by running lein repl (or make repl to run it on Docker) and run:

(require '[midje.repl :refer [autotest]])
(autotest :filter (complement :slow))

If you are working on a relatively isolated feature, you may want to make your own midje tag. This makes for faster autotesting and better feedback loop. For example, suppose we are working on Spark Streaming features, we may want to run:

(autotest :filter :streaming)

instead of (complement :slow), and start tagging midje facts with :streaming.

Release Checklist

  • Run make version-bumps or manually Bump the versions in:
    • project.clj.
    • lein-template's project.clj;
    • lein-template's resources/.../project.clj;
    • resources/GENI_REPL_RELEASED_VERSION;
    • docker/deps.edn; and
    • examples/geni-clj-app/deps.edn.
  • Ensure that the pre-release CI steps pass with make pre-release.
  • Deploy the main library with lein deploy clojars.
  • Ensure that the post-release CI steps pass with make post-release.
  • Deploy the lein template with lein deploy clojars.
  • Push the newly built container to DockerHub with make docker-release.
  • Merge the library version-bump branch.
  • Create a new release on GitHub with a summary of all the changes and the new uberjar uploaded.
  • Re-run failed CI pipeline due to the missing released uberjar.