Welcome to the Odestry open source collective! We're thrilled that you're interested in contributing to our projects. This document provides comprehensive guidelines for contributing to any Odestry project. By following these guidelines, you help maintain the quality of our codebase and ensure a positive experience for all contributors.
- Code of Conduct
- Getting Started
- How to Contribute
- Development Workflow
- Coding Standards
- Commit Guidelines
- Pull Request Process
- Code Review Process
- Issue Reporting Guidelines
- Security Vulnerabilities
- Documentation
- Testing
- Versioning
- Community
- License
We are committed to fostering an open and welcoming environment in the Odestry community. All contributors are expected to adhere to our Code of Conduct. Please read it thoroughly before participating in our projects.
- Ensure you have a GitHub account.
- Fork the desired Odestry repository to your GitHub account.
- Clone your fork locally:
git clone https://github.com/your-username/repository-name.git
- Set up your development environment as described in the project's README.
- Create a new branch for your work:
git checkout -b feature/your-feature-name
- Check the project's issue tracker for open issues or feature requests.
- If you're working on a new feature or significant change, open an issue to discuss it first.
- Make your changes in your feature branch.
- Test your changes thoroughly.
- Commit your changes (see Commit Guidelines).
- Push your branch to your fork on GitHub.
- Submit a pull request to the main repository.
- Always pull the latest changes from the main branch before starting new work.
- Create a new branch for each separate piece of work.
- Make logical atomic commits throughout your work.
- Push your work to your fork at least once a day.
- When your feature is complete, rebase your branch onto the latest main.
- Make sure all tests pass and add new tests for your feature if applicable.
- Follow the existing code style and conventions used in the project.
- Use meaningful and descriptive names for variables, functions, and classes.
- Write self-documenting code where possible.
- Keep functions small and focused on a single task.
- Use appropriate design patterns and SOLID principles.
- Avoid duplicate code (DRY principle).
- Handle errors and edge cases appropriately.
- Write comments for complex logic or when the code's purpose is not immediately clear.
- Use the present tense ("Add feature" not "Added feature").
- Use the imperative mood ("Move cursor to..." not "Moves cursor to...").
- Limit the first line to 72 characters or less.
- Reference issues and pull requests liberally after the first line.
- Use semantic commit messages:
feat:
for new featuresfix:
for bug fixesdocs:
for documentation changesstyle:
for formatting changesrefactor:
for code refactoringtest:
for adding or modifying testschore:
for maintenance tasks
Example:
feat: Add user authentication system
- Implement JWT token-based authentication
- Create login and registration endpoints
- Add middleware for protected routes
Closes #123
- Ensure your PR adheres to the Coding Standards.
- Update the README.md or relevant documentation with details of changes, if applicable.
- Add or update tests for your changes.
- Ensure the test suite passes and the application runs without errors.
- Fill in the provided pull request template.
- Include screenshots or animated GIFs in your pull request if it includes UI changes.
- Make sure your PR is up-to-date with the main branch. If not, rebase your branch.
- Be responsive to feedback and be prepared to make additional changes if requested.
- At least one core team member must approve the pull request before merging.
- Reviewers will look for code quality, test coverage, and adherence to project standards.
- Address all comments and suggestions from reviewers.
- Once approved, a core team member will merge your PR.
- Use the provided issue template when creating a new issue.
- Clearly describe the issue, including steps to reproduce for bugs.
- Include relevant information such as operating system, browser, or package versions.
- Tag the issue with appropriate labels (e.g., bug, enhancement, documentation).
- Be responsive to any follow-up questions or requests for additional information.
If you discover a security vulnerability, please DO NOT open an issue. Email [email protected] instead. We will work with you to address the vulnerability promptly.
- Keep README files, API documentation, and inline comments up-to-date.
- Document all public APIs, classes, and methods.
- Provide examples and use cases in the documentation where appropriate.
- Use clear and concise language, and proofread your writing.
- Write unit tests for all new code.
- Aim for high test coverage (at least 80% for new code).
- Write integration and end-to-end tests for critical paths.
- Ensure all tests pass before submitting a pull request.
- Do not decrease the overall test coverage of the project.
We follow Semantic Versioning (SemVer) for all our projects. Please ensure that version bumps are appropriate for the changes made.
- Join our Discord server to connect with other contributors.
- Participate in discussions on GitHub issues and pull requests.
- Help answer questions from other community members.
- Share your Odestry project contributions on social media.
By contributing to Odestry projects, you agree that your contributions will be licensed under the MIT License. All Odestry projects are released under the MIT License, and your contributions will be no exception.
Thank you for contributing to Odestry! Your efforts help us build better commerce tools together. If you have any questions or need further clarification on these guidelines, please don't hesitate to reach out to the community on our Discord server or open an issue in the repository.
Happy coding, and let's make commerce better, together!