]> git.openstreetmap.org Git - rails.git/blob - CONTRIBUTING.md
Merge remote-tracking branch 'upstream/pull/5335'
[rails.git] / CONTRIBUTING.md
1 # Contributing
2
3 * https://www.ruby-lang.org/ - The homepage of Ruby which has more links and some great tutorials.
4 * https://rubyonrails.org/ - The homepage of Rails, also has links and tutorials.
5
6 ## Assigning Issues
7
8 We don't assign issues to individual contributors. You are welcome to work on any
9 issue, and there's no need to ask first.
10
11 For more details see [our FAQ](FAQ.md)]
12
13 ## Coding style
14
15 We use [Rubocop](https://github.com/rubocop-hq/rubocop) (for ruby files)
16 and [ERB Lint](https://github.com/Shopify/erb-lint) (for erb templates)
17 to help maintain consistency in our code. You can run these utilities during
18 development to check that your code matches our guidelines:
19
20 ```
21 bundle exec rubocop
22 bundle exec rails eslint
23 bundle exec erblint .
24 ```
25
26 You can also install hooks to have git run checks automatically when
27 you commit using [overcommit](https://github.com/sds/overcommit) with:
28
29 ```
30 bundle exec overcommit --install
31 ```
32
33 ## Testing
34
35 Having a good suite of tests is very important to the stability and
36 maintainability of any code base. The tests in the `openstreetmap-website` code are
37 by no means complete, but they are extensive, and must continue to be
38 so with any new functionality which is written. Tests are also useful
39 in giving others confidence in the code you've written, and can
40 greatly speed up the process of merging in new code.
41
42 When contributing, you should:
43
44 * Write new tests to cover the new functionality you've added.
45 * Where appropriate, modify existing tests to reflect new or changed
46 functionality.
47 * Never comment out or remove a test just because it doesn't pass.
48
49 You can run the existing test suite with:
50
51 ```
52 bundle exec rails test:all
53 ```
54
55 You can run javascript tests with:
56
57 ```
58 bundle exec teaspoon
59 ```
60
61 You can view test coverage statistics by browsing the `coverage` directory.
62
63 The tests are automatically run on Pull Requests and other commits via github
64 actions. The results shown are within the PR display on github.
65
66 ## Static Analysis
67
68 We also perform static analysis of our code. You can run the analysis yourself with:
69
70 ```
71 bundle exec brakeman -q
72 ```
73
74 ## Comments
75
76 Sometimes it's not apparent from the code itself what it does, or,
77 more importantly, **why** it does that. Good comments help your fellow
78 developers to read the code and satisfy themselves that it's doing the
79 right thing.
80
81 When contributing, you should:
82
83 * Comment your code where necessary - explain the bits which
84 might be difficult to understand what the code does, why it does it
85 and why it should be the way it is.
86 * Check existing comments to ensure that they are not misleading.
87
88 ## i18n
89
90 If you make a change that involve the locale files (in `config/locales`) then please
91 only submit changes to the `en.yml` file. The other files are updated via
92 [Translatewiki](https://translatewiki.net/wiki/Translating:OpenStreetMap) and should
93 not be included in your pull request.
94
95 ### Copyright attribution
96
97 The list of attributions on the /copyright page is managed by the [OSMF Licensing
98 Working Group (LWG)](https://wiki.osmfoundation.org/wiki/Licensing_Working_Group).
99
100 If you want to add another attribution, or make changes to the text of an existing
101 attribution, please follow these steps:
102
103 * First, contact the LWG to discuss your proposed changes.
104 * If the LWG approves, please create a pull request with your proposed changes.
105 * Finally, please ask the LWG to formally approve the wording used in the pull request
106   (by having an LWG member comment on the PR).
107
108 When we have formal confirmation from LWG, we can go ahead and merge the PR.
109
110 ## Committing
111
112 When you submit your changes, the project maintainers have to read them and
113 understand them. This is difficult enough at the best of times, and
114 misunderstanding commits can lead to them being more difficult to
115 merge. To help with this, when committing you should:
116
117 * Split up large commits into smaller units of functionality.
118 * Keep your commit messages relevant to the changes in each individual
119 commit.
120
121 When writing commit messages please try and stick to the same style as
122 other commits, namely:
123
124 * A one line summary, starting with a capital and with no full stop.
125 * A blank line.
126 * Full description, as proper sentences with capitals and full stops.
127
128 For simple commits the one line summary is often enough and the body
129 of the commit message can be left out.
130
131 ## Pull Requests
132
133 If you have forked on GitHub then the best way to submit your patches is to
134 push your changes back to GitHub and then send a "pull request" on GitHub.
135
136 If your pull request is small, for example one or two commits each containing
137 only a few lines of code, then it is easy for the maintainers to review.
138
139 If you are creating a larger pull request, then please help the maintainers
140 with making the reviews as straightforward as possible:
141
142 * The smaller the PR, the easier it is to review. In particular if a PR is too
143   large to review in one sitting, or if changes are requested, then the
144   maintainer needs to repeatedly re-read code that has already been considered.
145 * The commit history is important. This is a large codebase, developed over many
146   years by many developers. We frequently need to read the commit history (e.g.
147   using `git blame`) to figure out what is going on. So small, understandable,
148   and relevant commits are important for other developers looking back at your
149   work in future.
150
151 If you are creating a large pull request then please:
152
153 * Consider splitting your pull request into multiple PRs. If part of your work
154   can be considered standalone, or is a foundation for the rest of your work,
155   please submit it separately first.
156 * Avoid including "fixup" commits. If you have added a fixup commit (for example
157   to fix a rubocop warning, or because you changed your own new code) please
158   combine the fixup commit into the commit that introduced the problem.
159   `git rebase -i` is very useful for this.
160 * Avoid including "merge" commits. If your PR can no longer be merged cleanly
161   (for example, an unrelated change to Gemfile.lock on master now conflicts with
162   your PR) then please rebase your PR onto the latest master. This allows you to
163   fix the conflicts, while keeping the PR a straightforward list of commits. If
164   there are no conflicts, then there is no need to rebase anything.