Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dustinmoris/CI-BuildStats
Little widget to display AppVeyor, TravisCI, CircleCI, GitHub Actions or Azure Pipelines build history charts and other SVG badges.
https://github.com/dustinmoris/CI-BuildStats
appveyor badge buildstats chart circleci fsharp myget-badge nuget-badge svg-widget travis-ci widget
Last synced: 2 months ago
JSON representation
Little widget to display AppVeyor, TravisCI, CircleCI, GitHub Actions or Azure Pipelines build history charts and other SVG badges.
- Host: GitHub
- URL: https://github.com/dustinmoris/CI-BuildStats
- Owner: dustinmoris
- License: gpl-2.0
- Created: 2015-08-27T13:51:32.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-12-15T10:12:39.000Z (about 1 year ago)
- Last Synced: 2024-08-01T16:23:52.139Z (5 months ago)
- Topics: appveyor, badge, buildstats, chart, circleci, fsharp, myget-badge, nuget-badge, svg-widget, travis-ci, widget
- Language: F#
- Homepage: https://buildstats.info
- Size: 648 KB
- Stars: 171
- Watchers: 5
- Forks: 25
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# [BuildStats.info](https://buildstats.info)
A little SVG widget to display build history charts and other badges for public repositories.![Build and Deploy](https://github.com/dustinmoris/CI-BuildStats/workflows/Build%20and%20Deploy/badge.svg?branch=develop)
[![Build History](https://buildstats.info/github/chart/dustinmoris/CI-BuildStats?branch=develop)](https://github.com/dustinmoris/CI-BuildStats/actions?query=branch%3Adevelop)
## Table of contents
- [Build History Chart](#build-history-chart)
- [How it works](#how-it-works)
- [Configuration](#configuration)
- [NuGet Badges](#nuget-badges)
- [MyGet Badges](#myget-badges)
- [Crates Badges](#crates-badges)
- [Docker image](#docker-image)
- [Contributing](#contributing)
- [Support](#support)## Build History Chart
The SVG widget currently works for public repositories built with:
### How it works
The base URL to the SVG widget is:
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}[/{definitionId}]
```Replace `{buildSystem}` with one of the supported build systems:
- appveyor
- travisci
- circleci
- azurepipelines
- githubReplace `{account}` and `{project}` with your personal values.
For example `https://buildstats.info/appveyor/chart/dustinmoris/ci-buildstats` displays the build history chart for this particular project.
The complete markdown for the above chart is as following:
```
[![Build history](https://buildstats.info/appveyor/chart/dustinmoris/ci-buildstats)](https://ci.appveyor.com/project/dustinmoris/ci-buildstats/history)
```The URL for an Azure Pipelines powered graph has an additional route argument for the definition ID which is an Azure Pipelines specific concept:
```
https://buildstats.info/azurepipelines/chart/MyAccount/MyProject/12
```### Configuration
#### Filtering for a specific branch
By default the widget will render a chart for builds from all branches.
You can select a specific branch by appending the `branch` parameter to the URL (optional):
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}?branch={branch}
```#### Changing the number of builds
You can specify the maximum build count by appending the `buildCount` parameter to the URL (optional):
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}?buildCount={number}
```#### Excluding builds from a pull request
Use the `includeBuildsFromPullRequest` parameter to include or exclude builds from a pull request (optional):
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}?includeBuildsFromPullRequest={true/false}
```#### Hiding the text
You can hide the build stats by appending the `showStats` parameter to the URL (optional):
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}?showStats={true/false}
```#### Full URL
The full URL to the SVG widget is:
```
https://buildstats.info/{buildSystem}/chart/{account}/{project}[?buildCount={buildCount}&branch={branch}&includeBuildsFromPullRequest={includeBuildsFromPullRequest}&showStats={true/false}]
```## NuGet Badges
The URL to the NuGet badge is:
```
https://buildstats.info/nuget/{packageName}
```For example the badge and Markdown for the [NUnit](https://github.com/nunit/nunit) NuGet badge would be:
[![NuGet Badge](https://buildstats.info/nuget/nunit)](https://www.nuget.org/packages/NUnit/)
```
[![NuGet Badge](https://buildstats.info/nuget/nunit)](https://www.nuget.org/packages/NUnit/)
```### Including PreRelease packages
You can append the `includePreReleases=true` flag to include pre-release packages:
[![NuGet Badge](https://buildstats.info/nuget/NServiceBus.PostgreSQL?includePreReleases=true)](https://www.nuget.org/packages/NServiceBus.PostgreSQL/1.0.0-CI00021)
```
[![NuGet Badge](https://buildstats.info/nuget/NServiceBus.PostgreSQL?includePreReleases=true)](https://www.nuget.org/packages/NServiceBus.PostgreSQL/1.0.0-CI00021)
```### Setting a specific package version
By adding the `packageVersion` query parameter you can set a specific version:
[![NuGet Badge](https://buildstats.info/nuget/Giraffe?packageVersion=3.0.0)](https://www.nuget.org/packages/Giraffe/3.0.0)
```
[![NuGet Badge](https://buildstats.info/nuget/NServiceBus.PostgreSQL?includePreReleases=true)](https://www.nuget.org/packages/NServiceBus.PostgreSQL/1.0.0-CI00021)
```### Setting a fixed width
If you want to control the width of the version and/or downloads label then you can use the `vWidth` and `dWidth` query parameters. Both accept an integer value representing the width in pixels:
[![NuGet Badge](https://buildstats.info/nuget/Giraffe?vWidth=100&dWidth=100)](https://www.nuget.org/packages/Giraffe)
```
[![NuGet Badge](https://buildstats.info/nuget/Giraffe?vWidth=100&dWidth=100)](https://www.nuget.org/packages/Giraffe)
```## MyGet Badges
MyGet badges are supported for both the standard MyGet feed as well as MyGet Enterprise customers.
The URL to a MyGet badge from the official feed is:
```
https://buildstats.info/myget/{feedName}/{packageName}
```For example the badge and Markdown for the FSharp.Core package in the .NET Core feed would be:
[![MyGet Badge](https://buildstats.info/myget/dotnet-core/FSharp.Core)](https://www.myget.org/feed/dotnet-core/package/nuget/FSharp.Core)
```
[![MyGet Badge](https://buildstats.info/myget/dotnet-core/NEventSocket)](https://www.myget.org/feed/dotnet-core/package/nuget/FSharp.Core)
```The URL to a MyGet badge from an Enterprise feed is:
```
https://buildstats.info/myget/{subDomain}/{feedName}/{packageName}
```For example the badge and Markdown for the [Microsoft.Bot.Builder](https://botbuilder.myget.org/feed/botbuilder-v4-dotnet-daily/package/nuget/Microsoft.Bot.Builder) MyGet badge would be:
[![MyGet Badge](https://buildstats.info/myget/botbuilder/botbuilder-v4-dotnet-daily/Microsoft.Bot.Builder?includePreReleases=true)](https://botbuilder.myget.org/feed/botbuilder-v4-dotnet-daily/package/nuget/Microsoft.Bot.Builder)
```
[![MyGet Badge](https://buildstats.info/myget/botbuilder/botbuilder-v4-dotnet-daily/Microsoft.Bot.Builder?includePreReleases=true)](https://botbuilder.myget.org/feed/botbuilder-v4-dotnet-daily/package/nuget/Microsoft.Bot.Builder)
```## Crates Badges
The URL to a Crates.io badge from the official feed is:
```
https://buildstats.info/crate/{crateName}
```For example the badge and Markdown for the [rand](https://github.com/rust-random/rand) Crates.io badge would be:
[![Crate Badge](https://buildstats.info/crate/rand)](https://crates.io/crates/rand)
```
[![Crate Badge](https://buildstats.info/crate/rand)](https://crates.io/crates/rand)
```### Setting a specific package version
By adding the `packageVersion` query parameter you can set a specific version:
[![Crate Badge](https://buildstats.info/crate/rand?packageVersion=0.7.0)](https://crates.io/crates/rand/0.7.0)
```
[![Crate Badge](https://buildstats.info/crate/rand?packageVersion=0.7.0)](https://crates.io/crates/rand/0.7.0)
```### Additional settings
The `includePreReleases`, `vWidth` and `dWidth` query parameters work the same way as for NuGet badges (see above for more information).
## Docker image
You can also self host the application by running [CI-BuildStats from a Docker container](https://hub.docker.com/r/dustinmoris/ci-buildstats/).
## Contributing
Feedback is welcome and pull requests get accepted.
## Support
If you've got value from any of the content which I have created, but pull requests are not your thing, then I would also very much appreciate your support by buying me a coffee.