Skip to content
This repository has been archived by the owner on Jan 13, 2022. It is now read-only.

Latest commit

 

History

History
105 lines (66 loc) · 3.73 KB

CONTRIBUTING.md

File metadata and controls

105 lines (66 loc) · 3.73 KB

Contributing to CC Open Source

Thank you for your interest in contributing to CC Open Source! This document is a set of guidelines to help you contribute to this project.


Code of Conduct

By participating in this project, you are expected to uphold our Code of Conduct.


Project Documentation

Please consult the README and CODEBASE files at the root of this repository.


How to Contribute

Please read the processes in our general Contributing Code guidelines on the Creative Common Open Source website. It contains some general instructions that should be followed when contributing to any of the Creative Commons open-source repositories.


Bugs

If you find a bug, please open an issue in this repository describing the bug. You can file a bug here. You will see a bug report template with the required information you should provide.

After that, don't forget to tag the issue with the "Bug" label.


Proposing changes or new features

If you have an idea of a new feature or change to how the CC Catalog API works, please file an issue so we can discuss the possibility of that change or new feature being implemented and released in the future. This lets us come to an agreement about the proposed idea before any work is done.

If you'd like to build a new feature but don't have a specific idea, please check our public roadmap. Choose something from the pipeline of ideas and follow the same process as above.


Pull requests

Before you start writing code, make sure there is an issue open. Pull requests without a link to an existing issue won't be merged.

If you want to get started contributing code to this project but don't know exactly what to work on, we compiled a good list of issues labeled as good first issue which are small in scope and not so complex to solve. There are also issues labeled as help wanted which can be a bit more complex but are good examples of things we are currently accepting help from the community.

Any code modifications will have to be accompanied by the appropriate unit tests. This will be checked and verified during code review. Once the Pull Request is opened, our CI server will run the unit test suite and run a code linter to verify that the code follows the coding guidelines.


Running the tests

How to Run API live integration tests

You can check the health of a live deployment of the API by running the live integration tests.

  1. Change directory to CC Catalog API
cd cccatalog-api
  1. Install all dependencies for CC Catalog API
pipenv install
  1. Launch a new shell session
pipenv shell
  1. Run API live integration test
./test/run_test.sh

How to Run Ingestion Server tests

You can ingest and index some dummy data using the Ingestion Server API.

  1. Change directory to ingestion server
cd ingestion_server
  1. Install all dependencies for Ingestion Server API
pipenv install
  1. Launch a new shell session
pipenv shell
  1. Run the integration tests
python3 test/integration_tests.py

Questions or Thoughts?

Talk to us on our developer mailing list or Slack community.