Skip to content

Latest commit

 

History

History
89 lines (65 loc) · 3.98 KB

CONTRIBUTING.md

File metadata and controls

89 lines (65 loc) · 3.98 KB

Contributing

This repository is far from underwhelmed by requests so feel free to file an issue for any of the cases mentioned below.

Reporting bugs

If you think you found a bug, please file an issue and try to provide a piece of code that triggers the bug. Indicate in which environment this bug happens and give some details on each affected environments (java version, jdk used, node version, browser + version).

For bug fixes, file an issue as instructed above and create a pull request referencing the issue. Bug fix pull requests should be based on master such that they can be deployed in the next minor update. Always try to provide a test case with your bug fix. If for some reason you can really not test your bug, let me know in your pull request comment.

Feature requests

Feel free to file an issue to request a feature, or even just to start a conversation related to the project. It is advised that you discuss any feature you would like to implement before starting working on it.

You can still provide proofs of concepts in pull requests based on develop. Once a feature has been approved, its development happens in a PR based on develop. New features must be tested.

Repository structure

The develop branch contains unpublished features for the next release. Ongoing feature development happens in dedicated branches based on develop. When new code is released, the develop branch is merged into master such that master always contains code for the latest stable release.
Except for important bug fixes, all pull requests should target develop.

Development

This project is built with sbt. While any IDE with decent sbt support would work, I recommend using idea with the scala plugin.

The sbt project contains two subprojects: scalaHttpJS and scalaHttpJVM. Run one of sbt scalaHttpJS/console or sbt scalaHttpJVM/console to start an interactive console with library code in the classpath.

You can run tests in 4 different environment using the following commands:

sbt scalaHttpJVM/test # Runs on your current JVM (default environment for Scala)
sbt scalaHttpJS/test  # Runs in Node.js
sbt chrome:test # Run in chrome*
sbt firefox:test # Runs in firefox*

*Browser testing may require additional software on your computer. See [https://github.com/scala-js/scala-js-env-selenium#scalajs-env-selenium] for more details.

The testing server needs to run on your machine while running the test commands.

Testing

All features are tested in HttpRequestSpec. In order to test this library, the testing server needs to run on the testing machine. This server enables us to run tests in a reproducible environment and to test edge cases.

To start the testing server, go to test/server and install the dependencies with npm install. This command must be run when there has been some updates in the test server dependencies.
Run the test server with node index.js.

If Node.js is not installed on your machine, do the following:

  • For Windows and Mac, download the latest LTS release from the official website.
  • For Linux users, I advise downloading Node.js through NVM

Code style

The code in this repository should follow Scala.js coding style guide as much as possible.

Other things you need to know

Environment-specific code lives in jvm/ and js/. The DriverTrait is the low-level interface between shared and specific code. Shared code is linked to the correct HttpDriver class by the Scala.js compiler.

All code that gets merged in this code base falls under the terms of the MIT license. By submitting a pull request to this repository, you consent that your code may be used, copied, and distributed by anyone as per the terms of the MIT license and that you are not responsible for the usage other parties may make of your code.