• Stars
    star
    213
  • Rank 185,410 (Top 4 %)
  • Language
    Python
  • License
    Other
  • Created over 1 year ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Code for the API of Codecov

Codecov API

We believe that everyone should have access to quality software (like Sentry), thatโ€™s why we have always offered Codecov for free to open source maintainers.

By making our code public, weโ€™re not only joining the community thatโ€™s supported us from the start โ€” but also want to make sure that every developer can contribute to and build on the Codecov experience.

A private Django REST Framework API intended to serve Codecov's front end.

Getting Started

Building

This project contains a makefile. To build the docker image:

make build

requirements.txt is used in the base image. If you make changes to requirements.txt you will need to rebuild.

Note, you'll need to install Rust to build ribs which is a dependency of shared. Go here for more info on how to do this: https://www.rust-lang.org/tools/install

Running Standalone

This project contains a docker-compose.yml file that is intended to run the api standalone. In this configuration it does not share codecov.io's development database; so don't expect parity there.

To start the service, do

docker-compose up

Utilizing its own database provides a convenient way for the REST API to provide its own helpful seeds and migrations for active development without potentially destroying/modifying your development database for codecov.io.

Once running, the api will be available at http://localhost:5100

Running with codecov.io

This service will startup when you run codecov.io normally. It is under that api block of codecov.io's docker-compose.yml file.

Testing

The easiest way to run tests (that doesn't require installing postgres and other dependencies) is to run inside of docker:

docker-compose up
docker exec -it codecov-api_api_1 pytest -rf

Testing standalone

If you would like to use pytest directly (Either through an IDE like PyCharm or with the CLI), you will need to change the settings file used by pytest. Run this command to have the tests executed (You will need an instance of postgres running locally):

RUN_ENV=TESTING DJANGO_SETTINGS_MODULE=codecov.settings_test pytest

Make sure to have all the requirements from requirements.txt installed.

Deploying

All work merged into the main branch is immediately deployed to the production environment. More context on this strategy can be found here.

Deploying to Staging environment

To deploy to our staging environment it's crucial to follow these steps:

  1. Check in Slack to see if anyone is currently using the staging environment
  2. If not, delete the current staging branch
  3. Create a new staging branch and merge your feature branch into it

Steps 2 and 3 are important to limit interaction between features not yet merged into main. This approach was inspired by this document: https://codecovio.atlassian.net/wiki/spaces/ENG/pages/507445249/Branching+and+Continuous+Delivery+Strategy+Proposal

Secret and Credential Management

This project should store no secrets or credentials in its source. If you need to add to / modify / setup secrets for this project, contact Eli and he'll get you started..

Adding dependencies

This repository uses pip-tools to manage dependencies, so make sure you've installed it with pip install pip-tools. To add or update dependencies, change requirements.in, Then run

pip-compile requirements.in

Do not change requirements.txt directly.

Formatting

This project uses black for formatting.
You can run the linter using the command make lint.

Migrations

We leverage Django's migration system to keep the state of our models in sync with the state of our database. You can read more about how we work with migrations at https://codecovio.atlassian.net/wiki/spaces/ENG/pages/1696530442/Migrations

Contributing

This repository, like all of Codecov's repositories, strives to follow our general Contributing guidlines. If you're considering making a contribution to this repository, we encourage review of our Contributing guidelines first.

More Repositories

1

codecov-action

GitHub Action that uploads coverage to Codecov โ˜‚๏ธ
TypeScript
1,469
star
2

self-hosted

Example of how to setup Codecov with docker compose
Shell
424
star
3

example-python

Python coverage example
Python
301
star
4

codecov-node

Global coverage report uploader for Codecov in NodeJS
JavaScript
292
star
5

codecov-bash

Global coverage report uploader for Codecov
Shell
233
star
6

browser-extension

Codecov Browser Extension
JavaScript
213
star
7

example-go

Go coverage example
Go
213
star
8

example-node

Example repo for uploading reports to Codecov
JavaScript
192
star
9

codecov-python

Python report uploader for Codecov
Python
184
star
10

example-android

Android code coverage example with https://codecov.io
Java
145
star
11

example-cpp11-cmake

CMake
144
star
12

example-swift

Codecov: Swift coverage example
Swift
127
star
13

example-csharp

Codecov: C# example repository
C#
115
star
14

uploader

Codecov's universal binary uploader.
TypeScript
104
star
15

timestring

Making time easier since "Jan 17th, 2013 at 3:59pm"
Python
101
star
16

example-rust

Rust
89
star
17

example-php

PHP coverage example
PHP
88
star
18

example-java-gradle

Java
86
star
19

sourcegraph-codecov

See code coverage information from Codecov on GitHub, Sourcegraph, and other tools.
TypeScript
74
star
20

codecov-ruby

Ruby uploader for Codecov
Ruby
72
star
21

example-java

Java Example
70
star
22

example-java-maven

Java
58
star
23

example-bash

Codecov: Bash/Shell coverage example
Ruby
50
star
24

codecov-cli

Codecov's Command Line Interface. Used for uploading to Codecov in your CI, Test Labelling, Local Upload, and more
Python
50
star
25

worker

Code for Background Workers of Codecov
Python
47
star
26

example-typescript

Example repo for uploading reports to Codecov https://codecov.io
TypeScript
47
star
27

gazebo

React SPA
TypeScript
45
star
28

example-c

Upload reports to Codecov using C/C++
C
35
star
29

example-scala

Scala coverage example
Scala
35
star
30

codecov-browser-extension

A browser extension for Codecov. Works for Chrome and Firefox
TypeScript
35
star
31

feedback

A place to discuss feedback about the pull request and web product experience.
34
star
32

opentelem-laravel

A WIP exporter for Laravel to capture and export opentelem data.
PHP
33
star
33

dart

Codecov Dart coverage report uploader
Dart
29
star
34

example-objc

Codecov example for Xcode
Objective-C
26
star
35

codecov-exe

.exe report uploader for Codecov https://codecov.io
C#
25
star
36

example-perl

Perl
23
star
37

example-fortran

Example repo for uploading reports to Codecov
Fortran
22
star
38

codecov-circleci-orb

Python
20
star
39

example-ruby

Ruby coverage example
Ruby
20
star
40

swift-standard

Codecov coverage standard for Swift
Swift
19
star
41

example-kotlin

Kotlin coverage example
Kotlin
19
star
42

example-r

R
17
star
43

example-elixir

Elixir
16
star
44

go-standard

Codecov coverage standard for go
Python
14
star
45

codecov-perl

Backend for Codecov reporting of coverage
Perl
14
star
46

contributing

14
star
47

example-clojure

Example Clojure integration with Codecov
Clojure
14
star
48

python-standard

Codecov coverage standard for Python
Python
14
star
49

shared

Shared code between worker and api
Python
13
star
50

example-vala

Vala
12
star
51

cf-flags-demo

A demo of Codecov's carryforward flags feature.
Python
12
star
52

example-julia

Julia
11
star
53

example-d

Example repository for D and Codecov
D
10
star
54

kotlin-standard

Codecov coverage standard for Kotlin
Kotlin
9
star
55

typescript-standard

Codecov coverage standard for TypeScript
JavaScript
9
star
56

java-standard

Codecov coverage standard for Java
Python
9
star
57

standards

List of Codecov language standards
C++
8
star
58

example-groovy

Groovy coverage example
Groovy
7
star
59

example-lua

Shell
7
star
60

vscode

A Codecov vscode extention which helps validate and configure new repositories.
Python
7
star
61

cpp-11-standard

Codecov coverage standard for c++ 11
C++
6
star
62

helm-charts

Public Helm Charts
6
star
63

example-fsharp

Example of codecov in fsharp
F#
6
star
64

example-actions-bundled

Python
5
star
65

codecov-demo-full

JavaScript
5
star
66

codecov-racket

Codecov support for Cover.
Racket
5
star
67

opentelem-node

A WIP OpenTelemetry Exporter for Runtime Insights
JavaScript
4
star
68

example-erlang

Erlang
4
star
69

example-cpp

4
star
70

nginx

Dockerfile
4
star
71

test-results-action

TypeScript
4
star
72

codecov-javascript-bundler-plugins

Set of bundler plugins that allow users to upload bundle stats to Codecov.
TypeScript
4
star
73

media

Press and marketing resources
3
star
74

example-xtend

Xtend coverage example
Xtend
3
star
75

example-scala-maven

Scala via Maven coverage example
Scala
3
star
76

codecov-ats

GitHub Action that uploads returns selected test labels to CI โ˜‚๏ธ
Shell
3
star
77

ruby-standard-2

Codecov coverage standard for Ruby using Codecov's Bash uploader
Ruby
3
star
78

example-haskell

3
star
79

example-delphi

2
star
80

ruby-standard-1

Codecov coverage standard for Ruby using the Codecov gem
Ruby
2
star
81

example-csharp-sharpcover

C#
2
star
82

example-azure-pipelines

Azure Pipelines coverage example
Python
2
star
83

example-kotlin-flat

Kotlin codecov example with standard file structure
Kotlin
2
star
84

opentelem-python

Open Telemetry Python Prototype
Python
2
star
85

enterprise-rhe

Shell
2
star
86

codecov-slack-app

Python
2
star
87

codecov-bitrise

Shell
1
star
88

node-static-alpine

Internal Node builder for the Alpine version of the uploader
1
star
89

example-java-ant

1
star
90

impact-analysis-example-laravel

An example repository demonstrating runtime insights with Laravel
PHP
1
star
91

example-gradle-multiproject

Java
1
star
92

xcode-poc

Swift
1
star
93

ci-repo

debug and ci only
Python
1
star
94

prometheus

Shell
1
star
95

example-javascript

JavaScript
1
star
96

.github

Community Health Files for the Codecov Organization
1
star
97

engineering-team

This is a general repo to use with GH Projects
1
star
98

grafana

Dockerfile
1
star
99

node-alpine-static

Builds a fully static copy of NodeJS from source to be used by codecov/uploader
1
star
100

codecov-interview-api

Python
1
star