Add internal flag to enable/disable H264 hardware encoder
[WebKit-https.git] / JSTests / ChakraCore / CONTRIBUTING.md
1 # Contributing Code
2
3 ChakraCore accepts bug fix pull requests. For a bug fix PR to be accepted, it must first have a tracking issue that has been marked approved. Your PR should link to the bug you are fixing. If you've submitted a PR for a bug, please post a comment in the bug to avoid duplication of effort.
4
5 ChakraCore also accepts new feature pull requests. For a feature-level PR to be accepted, it first needs to have design discussion. Design discussion can take one of two forms a) a feature request in the issue tracker that has been marked as approved or b) the PR must be accompanied by a full design spec and this spec is later approved in the open design discussion. Features are evaluated against their complexity, impact on other features, roadmap alignment, and maintainability.
6
7 These two blogs posts on contributing code to open source projects are a good reference: [Open Source Contribution Etiquette](http://tirania.org/blog/archive/2010/Dec-31.html) by Miguel de Icaza and [Don't "Push" Your Pull Requests](https://www.igvita.com/2011/12/19/dont-push-your-pull-requests/) by Ilya Grigorik.
8
9 ## Security
10
11 If you believe you have found a security issue in ChakraCore, please share it with us privately following the guidance at the Microsoft [Security TechCenter](https://technet.microsoft.com/en-us/security/ff852094). Reporting it via this channel helps minimize risk to projects built with ChakraCore.
12
13 ## Legal
14
15 You will need to complete a Contributor License Agreement (CLA) before your pull request can be accepted. This agreement testifies that you are granting us permission to use the source code you are submitting, and that this work is being submitted under appropriate license that we can use it.
16
17 You can complete the CLA by going through the steps at https://cla.microsoft.com. Once we have received the signed CLA, we'll review the request. You will only need to do this once.
18
19 ## Housekeeping
20
21 Your pull request should:
22 * Include a description of what your change intends to do
23 * Be a child commit of a reasonably recent commit in the master branch
24 * Pass all unit tests
25 * Have a clear commit message
26 * Include adequate tests
27   * At least one test should fail in the absence of your non-test code changes. If your PR does not match this criteria, please specify why
28   * Tests should include reasonable permutations of the target fix/change
29   * Include baseline changes with your change
30
31 Submissions that have met these requirements will be assigned to a ChakraCore team member for additional testing. Submissions must meet functional and performance expectations, including meeting requirements in scenarios for which the team doesn’t yet have open source tests. This means you may be asked to fix and resubmit your pull request against a new open test case if it fails one of these tests. The ChakraCore team may verify your change by crawling the web with your change built into Chakra. Failures discovered when testing with this technique will not be analyzed by the team, but we will do our best to communicate the issue discovered to you. This approach needs further refinement, we acknowledge.
32
33 ChakraCore is an organically grown codebase. The consistency of style reflects this. For the most part, the team follows these [coding conventions](https://github.com/Microsoft/ChakraCore/wiki/Coding-Convention). Contributors should also follow them when making submissions. Otherwise, follow the general coding conventions adhered to in the code surrounding your changes. Pull requests that reformat the code will not be accepted.
34
35 ## Running the tests
36
37 The unit tests can be run by following these steps:
38 * Choose a build configuration to build and test, e.g. debug and x64.
39 * Build `Chakra.Core.sln` for that config.
40   * Specifically, running tests requires that `rl.exe`, `ch.exe`, and `ChakraCore.dll` be built.
41 * Call `test\runtests.cmd` and specify the build config
42
43 e.g.  `test\runtests.cmd -x64debug`
44
45 For full coverage, please run unit tests against debug and test for both x86 and x64:
46 * `test\runtests.cmd -x64debug`
47 * `test\runtests.cmd -x64test`
48 * `test\runtests.cmd -x86debug`
49 * `test\runtests.cmd -x86test`
50
51 `runtests.cmd` can take more switches that are useful for running a subset of tests.  Read the script file for more information.
52
53 `runtests.cmd` looks for the build output in the default build output folder `Build\VcBuild\bin`. If the build output path is changed from this default then use the `-bindir` switch to specify that path.
54
55 ## Code Flow into Microsoft Edge
56
57 Changes that make it into our ChakraCore GitHub master branch have a short journey to Chakra.dll. Code flows daily from GitHub to the internal repository from which builds of Chakra.dll are produced and then it flows into Windows and Microsoft Edge. While code flows quickly on this first leg of the journey, code flow from our internal branch to a Windows flighting branch is subject to any number of delays. So it is difficult to predict when your change in our GitHub repo will make it into a particular Windows flight.
58
59 ## Issue Labels
60
61  - [`Accepting PRs`](https://github.com/Microsoft/ChakraCore/labels/Accepting%20PRs): these issues are specifically well suited for outside contributors.
62  - [`Your first PR`](https://github.com/Microsoft/ChakraCore/labels/Your%20first%20PR): these issues are small and appropriate for people who wish to familiarize themselves with GitHub pull requests and/or ChakraCore's contributor guidelines, build process, and running tests.  We're here to help you get started in open source.
63
64 You are welcome to work on issues that are not tagged with these labels. However, issues without these labels are often deeply involved with the requirements of the various components of ChakraCore. Therefore, please be sure to touch base with a maintainer via comments on the issue before attempting to solve it.
65
66 Remember, for all issues you choose to work on please communicate on the issue that you are claiming it to avoid duplicated work.
67
68 To learn more about our GitHub labels see the [Label Glossary](https://github.com/Microsoft/ChakraCore/wiki/Label-Glossary) on our wiki page.