openapi-generator/CONTRIBUTING.md

75 lines
5.8 KiB
Markdown
Raw Normal View History

2015-12-07 08:38:07 +00:00
# Guidelines For Contributing
2015-12-07 08:36:32 +00:00
## Before submitting an issue
2016-06-08 13:20:03 +00:00
- If you're not using the latest master to generate API clients or server stubs, please give it another try by pulling the latest master as the issue may have already been addressed. Ref: [Getting Started](https://github.com/swagger-api/swagger-codegen#getting-started)
2016-01-23 15:20:26 +00:00
- Search the [open issue](https://github.com/swagger-api/swagger-codegen/issues) and [closed issue](https://github.com/swagger-api/swagger-codegen/issues?q=is%3Aissue+is%3Aclosed) to ensure no one else has reported something similar before.
2016-06-08 13:21:39 +00:00
- File an [issue ticket](https://github.com/swagger-api/swagger-codegen/issues/new) by providing all the required information.
- You can also make a suggestion or ask a question by opening an "issue".
2015-12-07 08:36:32 +00:00
## Before submitting a PR
- Search the [open issue](https://github.com/swagger-api/swagger-codegen/issues) to ensure no one else has reported something similar and no one is actively working on similar proposed change.
- If no one has suggested something similar, open an ["issue"](https://github.com/swagger-api/swagger-codegen/issues) with your suggestion to gather feedback from the community.
2016-07-04 23:46:42 +00:00
- It's recommended to **create a new git branch** for the change so that the merge commit message looks nicer in the commit history.
2015-12-07 08:36:32 +00:00
## How to contribute
### Code generators
All the code generators can be found in [modules/swagger-codegen/src/main/java/io/swagger/codegen/languages](https://github.com/swagger-api/swagger-codegen/tree/master/modules/swagger-codegen/src/main/java/io/swagger/codegen/languages)
### Templates
All the templates ([mustache](https://mustache.github.io/)) can be found in [modules/swagger-codegen/src/main/resources](https://github.com/swagger-api/swagger-codegen/tree/master/modules/swagger-codegen/src/main/resources).
For a list of variables available in the template, please refer to this [page](https://github.com/swagger-api/swagger-codegen/wiki/Mustache-Template-Variables)
### Style guide
Code change should conform to the programming style guide of the respective langauages:
2016-06-13 16:18:48 +00:00
- Android: https://source.android.com/source/code-style.html
2015-12-07 08:36:32 +00:00
- C#: https://msdn.microsoft.com/en-us/library/vstudio/ff926074.aspx
2016-06-23 10:08:56 +00:00
- C++: https://google.github.io/styleguide/cppguide.html
2016-06-13 16:52:34 +00:00
- Haskell: https://github.com/tibbe/haskell-style-guide/blob/master/haskell-style.md
2015-12-07 08:36:32 +00:00
- Java: https://google.github.io/styleguide/javaguide.html
2016-04-07 06:43:32 +00:00
- JavaScript: https://github.com/airbnb/javascript/tree/master/es5
2016-06-13 16:53:57 +00:00
- Groovy: http://groovy-lang.org/style-guide.html
2016-04-07 06:43:32 +00:00
- Go: https://github.com/golang/go/wiki/CodeReviewComments
2015-12-07 08:36:32 +00:00
- ObjC: https://github.com/NYTimes/objective-c-style-guide
2016-04-07 06:43:32 +00:00
- Perl: http://perldoc.perl.org/perlstyle.html
2015-12-07 08:36:32 +00:00
- PHP: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md
- Python: https://www.python.org/dev/peps/pep-0008/
- Ruby: https://github.com/bbatsov/ruby-style-guide
2016-06-13 16:53:57 +00:00
- Scala: http://docs.scala-lang.org/style/
- Swift: https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/TheBasics.html
2015-12-07 08:36:32 +00:00
- TypeScript: https://github.com/Microsoft/TypeScript/wiki/Coding-guidelines
For other languages, feel free to suggest.
You may find the current code base not 100% conform to the coding style and we welcome contributions to fix those.
For [Vendor Extensions](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md#vendorExtensions), please follow the naming convention below:
- For general vendor extension, use lower case and hyphen. e.g. `x-is-unique`, `x-content-type`
- For language-specified vendor extension, put it in the form of `x-{lang}-{extension-name}`. e.g. `x-objc-operation-id`, `x-java-feign-retry-limit`
2016-06-29 06:32:23 +00:00
- For a list of existing vendor extensions in use, please refer to https://github.com/swagger-api/swagger-codegen/wiki/Vendor-Extensions. If you've addaed new vendor extensions as part of your PR, please update the wiki page.
2015-12-07 08:36:32 +00:00
### Testing
To add test cases (optional) covering the change in the code generator, please refer to [modules/swagger-codegen/src/test/java/io/swagger/codegen](https://github.com/swagger-api/swagger-codegen/tree/master/modules/swagger-codegen/src/test/java/io/swagger/codegen)
To test the templates, please perform the following:
- Update the [Petstore](http://petstore.swagger.io/) sample by running the shell script under `bin` folder. For example, run `./bin/ruby-petstore.sh` to update the Ruby PetStore API client under [`samples/client/petstore/ruby`](https://github.com/swagger-api/swagger-codegen/tree/master/samples/client/petstore/ruby) For Windows, the batch files can be found under `bin\windows` folder. (If you find that there are new files generated or unexpected changes as a result of the update, that's not unusual as the test cases are added to the OpenAPI/Swagger spec from time to time. If you've questions or concerns, please open a ticket to start a discussion)
2015-12-07 08:36:32 +00:00
- Run the tests in the sample folder, e.g. in `samples/client/petstore/ruby`, run `mvn integration-test -rf :RubyPetstoreClientTests`. (some languages may not contain unit testing for Petstore and we're looking for contribution from the community to implement those tests)
- Finally, git commit the updated samples files: `git commit -a`
(`git add -A` if added files with new test cases)
To start the CI tests, you can run `mvn verify -Psamples` (assuming you've all the required tools installed to run tests for different languages) or you can leverage http://travis-ci.org to run the CI tests by adding your own Swagger-Codegen repository.
### Tips
- Smaller changes are easier to review
2015-12-30 22:52:15 +00:00
- [Optional] For bug fixes, provide a OpenAPI Spec to repeat the issue so that the reviewer can use it to confirm the fix
2015-12-07 08:36:32 +00:00
- Add test case(s) to cover the change
- Document the fix in the code to make the code more readable
- Make sure test cases passed after the change (one way is to leverage https://travis-ci.org/ to run the CI tests)