summaryrefslogtreecommitdiff
path: root/CONTRIBUTING.md
blob: 4bcea1046cc79bd949a02437a9526a3b30d4c357 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
How to contribute to noVNC
==========================

We accept code via pull requests on GitHub.  There are several guidelines that
we expect contributors submitting code requests to follow.  If you have issues
following any of these guidelines, feel free to drop us a line by leaving a
comment in the code request or sending us an email.

Contributing Guidelines
-----------------------

* While we don't have an official coding style guide, please try to follow
  the general coding style of the existing code.
** Use four spaces instead of tabs 
** prefix private variables and functions with an `_`

* Please try to include unit tests for your code.  For instance, if you
  introduce a new encoding, add a test to `tests/test.rfb.js` under the
  "Encoding Handlers" section (basically, input a small pattern in your
  encoding and make sure the pattern gets displayed correctly).  If you
  fix a bug, try to add a unit test that would have caught that bug
  (if possible -- some bugs, especially visual ones, are hard to test for).

* Squash your commits down in to a clean commit history.  For instance, there
  should not be "cleanup" commits where you fix issues in previous commits in
  the same pull request.  Before you go to commit, use `git rebase -i` to
  squash these changes into the relevant commits.  For instance, a good commit
  history might look like "Added support for FOO encoding, Added support for
  BAR message, Placed Button in UI to Trigger BAR" (where each comma denotes
  a separate commit).

* Add both a title and description to your commit, if possible.  Place more
  detail on what you did in the description.

Running the unit tests
----------------------

There are two ways to run the unit tests.  For both ways, you should first run
`npm install` (not as root).

The first way to run the tests is to run `npm test`.  This will run all the
tests in the headless PhantomJS browser (which uses WebKit).

The second way to run the tests is using the `tests/run_from_console.js` file.
This way is a bit more flexible, and can provide more information about what
went wrong.  To run all the tests, simply run `tests/run_from_console.js`.
To run a specific test file, you can use the `-t path/to/test/file.js` option.
If you wish to simply generate the HTML for the test, use the `-g` option, and
the path to the temporary HTML file will be written to standard out.  To open
this file in your default browser automatically, pass the `-o` option as well.
More information can be found by passing the `--help` or `-h` option.


Thanks, and happy coding!