Please note that as of August 2023, signed commits are required for all contributions to this project. For more information on how to set up, see the GitHub Authentication verify commit signature documentation.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
Microsoft Teams is currently accepting contributions in the form of bug fixes and new features. Any submission must have an issue tracking it in the issue tracker that has been approved by the Teams AI team. Your pull request should include a link to the bug that you are fixing. If you've submitted a PR for a bug, please post a comment in the bug to avoid duplication of effort.
If your contribution is more than 15 lines of code, you will need to complete a Contributor License Agreement (CLA). Briefly, this agreement testifies that you are granting us permission to use the submitted change according to the terms of the project's license, and that the work being submitted is under appropriate copyright.
Please submit a Contributor License Agreement (CLA) before submitting a pull request. You may visit https://cla.azure.com to sign digitally. Alternatively, download the agreement (Microsoft Contribution License Agreement.docx or Microsoft Contribution License Agreement.pdf), sign, scan, and email it back to cla@microsoft.com. Be sure to include your github user name along with the agreement. Once we have received the signed CLA, we'll review the request.
Below are sections of information you may need when contributing to our repository.
At the time of writing, this repository does not have daily builds. To check the latest status of daily builds, please see Daily Builds information.
If making changes to our main package(s), (at time of writing, teams-ai
is the only published package in this repo), it may be necessary to test samples using local bits. By default, all samples will use the latest published version of teams-ai
. To run a sample using local bits, please do the following:
-
Update the
teamsapp.local.yml
and comment out the step to runnpm install
.- - uses: cli/runNpmCommand - name: install dependencies - with: - args: install --no-audit
-
Do not run npm install or build in the sample root. Instead use
yarn
to hoist packages and use the latest changes from theteams-ai
package.- If not already installed, install yarn globally.
- Delete
node_modules
andpackage-lock.json
from the sample, if applicable.
-
Navigate to the root
js
folder. -
In the
js
directory, runyarn && yarn build
to hoist and install all dependencies, plus build all packages (including the samples). -
To run/use a sample, open that sample in it's own VS Code instance e.g.
code js/samples/path-to-sample
. -
With the changes listed above, you will be able to run the sample using latest bits, even while using TTK. Further information on running the samples can be found within the sample README.md.
-
Revert these changes before making commits or if you need to use the latest published package.
- All PRs must indicate what programming language they are for in the title with a prefix of [JS], [C#] [PY], or [repo].
- All PRs must be prepended with one of the following keywords:
- 'bump' - indicates a change to the version number of the package
- note: ':' was removed and 'Bump' (capitalized) allowed since dependabot automatically starts all PR titles with 'Bump'
- 'chore:' - indicates a change to the build process or auxiliary tools
- 'docs:' - indicates a change to the documentation
- 'feat:' - indicates a new feature
- 'fix:' - indicates a bug fix
- 'port:' - indicates a port of a feature from another language
- 'refactor:' - indicates a code change that neither fixes a bug nor adds a feature
- 'bump' - indicates a change to the version number of the package
- All PRs must have an associated work item link in the title and the body of the PR, unless the change is marked as #minor in the PR details.
- e.g. [JS] feat: #999 Add new feature
The purpose of this is to allow for easier filtering when creating changelogs and release notes.