• Stars
    star
    174
  • Rank 219,104 (Top 5 %)
  • Language
    Python
  • License
    MIT License
  • Created over 6 years ago
  • Updated 10 months ago

Reviews

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

Repository Details

A bot that integrates with GitHub and your favorite continuous integration service

Homu

Hommando

Homu is a bot that integrates with GitHub and your favorite continuous integration service such as Travis CI, Appveyor or Buildbot.

Why is it needed?

Let's take Travis CI as an example. If you send a pull request to a repository, Travis CI instantly shows you the test result, which is great. However, after several other pull requests are merged into the master branch, your pull request can still break things after being merged into master. The traditional continuous integration solutions don't protect you from this.

In fact, that's why they provide the build status badges. If anything pushed to master is completely free from any breakage, those badges will not be necessary, as they will always be green. The badges themselves prove that there can still be some breakages, even when continuous integration services are used.

To solve this problem, the test procedure should be executed just before the merge, not just after the pull request is received. You can manually click the "restart build" button each time before you merge a pull request, but Homu can automate this process. It listens to the pull request comments, waiting for an approval comment from one of the configured reviewers. When the pull request is approved, Homu tests it using your favorite continuous integration service, and only when it passes all the tests, it is merged into master.

Note that Homu is not a replacement of Travis CI, Buildbot or Appveyor. It works on top of them. Homu itself doesn't have the ability to test pull requests.

Influences of bors

Homu is largely inspired by bors. The concept of "tests should be done just before the merge" came from bors. However, there are also some differences:

  1. Stateful: Unlike bors, which intends to be stateless, Homu is stateful. It means that Homu does not need to retrieve all the information again and again from GitHub at every run. This is essential because of GitHub's rate limiting. Once it downloads the initial state, the following changes are delivered with the Webhooks API.
  2. Pushing over polling: Homu prefers pushing wherever possible. The pull requests from GitHub are retrieved using Webhooks, as stated above. The test results from Buildbot are pushed back to Homu with the HttpStatusPush feature. This approach improves the overall performance and the response time, because the bot is informed about the status changes immediately.

And also, Homu has more features, such as rollup, try, and the Travis CI & Appveyor support.

Usage

How to install

$ sudo apt-get install python3-venv python3-wheel
$ python3 -m venv .venv
$ . .venv/bin/activate
$ pip install -U pip
$ git clone https://github.com/rust-lang/homu.git
$ pip install -e homu

How to configure

In the following instructions, HOST refers to the hostname (or IP address) where you are running your custom homu instance. PORT is the port the service is listening to and is configured in web.port in cfg.toml. NAME refers to the name of the repository you are configuring homu for.

  1. Copy cfg.sample.toml to cfg.toml. You'll need to edit this file to set up your configuration. The following steps explain where you can find important config values.

  2. Create a GitHub account that will be used by Homu. You can also use an existing account. In the developer settings, go to "OAuth Apps" and create a new application:

    • Make note of the "Client ID" and "Client Secret"; you will need to put them in your cfg.toml.
    • The OAuth Callback URL should be http://HOST:PORT/callback.
    • The homepage URL isn't necessary; you could set http://HOST:PORT/.
  3. Go back to the developer settings of the GitHub account you created/used in the previous step. Go to "Personal access tokens". Click "Generate new token" and choose the "repo" and "user" scopes. Put the token value in your cfg.toml.

  4. Add your new GitHub account as a Collaborator to the GitHub repo you are setting up homu for. This can be done in repo (NOT user) "Settings", then "Collaborators". Enable "Write" access.

    4.1. Make sure you login as the new GitHub account and that you accept the collaborator invitation you just sent!

  5. Add a Webhook to your repository. This is done under repo (NOT user) "Settings", then "Webhooks". Click "Add webhook", then set:

    • Payload URL: http://HOST:PORT/github
    • Content type: application/json
    • Secret: The same as repo.NAME.github.secret in cfg.toml
    • Events: click "Let me select individual events", then pick Issue comments, Pull requests, Pushes, Statuses, Check runs
  6. Add a Webhook to your continuous integration service, if necessary. You don't need this if using Travis/Appveyor.

    • Buildbot

      Insert the following code to the master.cfg file:

      from buildbot.status.status_push import HttpStatusPush
      
      c['status'].append(HttpStatusPush(
         serverUrl='http://HOST:PORT/buildbot',
         extra_post_params={'secret': 'repo.NAME.buildbot.secret in cfg.toml'},
      ))
  7. Go through the rest of your cfg.toml and uncomment (and change, if needed) parts of the config you'll need.

How to run

$ . .venv/bin/activate
$ homu

More Repositories

1

rust

Empowering everyone to build reliable and efficient software.
Rust
85,122
star
2

rustlings

πŸ¦€ Small exercises to get you used to reading and writing Rust code!
Rust
47,148
star
3

mdBook

Create book from markdown files. Like Gitbook but implemented in Rust
Rust
15,892
star
4

book

The Rust Programming Language
Rust
13,981
star
5

rust-analyzer

A Rust compiler front-end for IDEs
Rust
13,571
star
6

cargo

The Rust package manager
Rust
11,293
star
7

rust-clippy

A bunch of lints to catch common mistakes and improve your Rust code. Book: https://doc.rust-lang.org/clippy/
Rust
9,860
star
8

rust-by-example

Learn Rust with examples (Live code editor included)
6,109
star
9

rustup

The Rust toolchain installer
Rust
5,558
star
10

rustfmt

Format Rust code
Rust
5,524
star
11

rfcs

RFCs for changes to Rust
Markdown
5,390
star
12

futures-rs

Zero-cost asynchronous programming in Rust
Rust
5,119
star
13

rust-bindgen

Automatically generates Rust FFI bindings to C (and some C++) libraries.
Rust
3,830
star
14

rust.vim

Vim configuration for Rust.
Vim Script
3,628
star
15

miri

An interpreter for Rust's mid-level intermediate representation
Rust
3,581
star
16

rls

Repository for the Rust Language Server (aka RLS)
Rust
3,513
star
17

regex

An implementation of regular expressions for Rust. This implementation uses finite automata and guarantees linear time matching on all inputs.
Rust
3,083
star
18

crates.io

The Rust package registry
Rust
2,554
star
19

hashbrown

Rust port of Google's SwissTable hash map
Rust
2,266
star
20

log

Logging implementation for Rust
Rust
2,180
star
21

this-week-in-rust

Data for this-week-in-rust.org
HTML
1,826
star
22

libc

Raw bindings to platform APIs for Rust
Rust
1,786
star
23

chalk

An implementation and definition of the Rust trait system using a PROLOG-like logic solver
Rust
1,713
star
24

async-book

Asynchronous Programming in Rust
Shell
1,699
star
25

nomicon

The Dark Arts of Advanced and Unsafe Rust Programming
CSS
1,698
star
26

rustc-dev-guide

A guide to how rustc works and how to contribute to it.
HTML
1,580
star
27

rustc_codegen_cranelift

Cranelift based backend for rustc
Rust
1,538
star
28

git2-rs

libgit2 bindings for Rust
Rust
1,520
star
29

cc-rs

Rust library for build scripts to compile C/C++ code into a Rust library
Rust
1,491
star
30

vscode-rust

Rust extension for Visual Studio Code
TypeScript
1,386
star
31

polonius

Defines the Rust borrow checker.
Rust
1,255
star
32

api-guidelines

Rust API guidelines
1,202
star
33

reference

The Rust Reference
Rust
1,140
star
34

rust-playground

The Rust Playground
Rust
1,076
star
35

rust-mode

Emacs configuration for Rust
Emacs Lisp
1,009
star
36

docs.rs

crates.io documentation generator
Rust
891
star
37

rustc_codegen_gcc

libgccjit AOT codegen for rustc
Rust
875
star
38

rustfix

Automatically apply the suggestions made by rustc
Rust
853
star
39

portable-simd

The testing ground for the future of portable SIMD in Rust
Rust
816
star
40

datafrog

A lightweight Datalog engine in Rust
Rust
783
star
41

flate2-rs

DEFLATE, gzip, and zlib bindings for Rust
Rust
730
star
42

socket2

Advanced configuration options for sockets.
Rust
681
star
43

unsafe-code-guidelines

Forum for discussion about what unsafe code can and can't do
641
star
44

rust-semverver

Automatic checking for semantic versioning in library crates
Rust
639
star
45

stdarch

Rust's standard library vendor-specific APIs and run-time feature detection
Rust
597
star
46

crater

Run experiments across parts of the Rust ecosystem!
Rust
588
star
47

packed_simd

Portable Packed SIMD Vectors for Rust standard library
Rust
575
star
48

rustc-perf

Website for graphing performance of rustc
Rust
539
star
49

libm

A port of MUSL's libm to Rust.
Rust
499
star
50

cfg-if

A if/elif-like macro for Rust #[cfg] statements
Rust
479
star
51

crates.io-index

Registry index for crates.io
476
star
52

backtrace-rs

Backtraces in Rust
Rust
473
star
53

style-team

Home of the Rust style team
Rust
438
star
54

docker-rust

The official Docker images for Rust
Dockerfile
414
star
55

glob

Support for matching file paths against Unix shell style patterns.
Rust
381
star
56

rust-forge

Information useful to people contributing to Rust
Rust
380
star
57

compiler-team

A home for compiler team planning documents, meeting minutes, and other such things.
HTML
380
star
58

wg-async

Working group dedicated to improving the foundations of Async I/O in Rust
Rust
365
star
59

www.rust-lang.org

The home of the Rust website
Fluent
358
star
60

compiler-builtins

Porting `compiler-rt` intrinsics to Rust
Rust
328
star
61

measureme

Support crate for rustc's self-profiling feature
Rust
324
star
62

rustc-hash

Custom hash algorithm used by rustc (plus hashmap/set aliases): fast, deterministic, not secure
Rust
312
star
63

blog.rust-lang.org

The Rust Programming Language Blog
HTML
302
star
64

team

Rust teams structure
Rust
293
star
65

glacier

A big 'ol pile of ICE.
Rust
289
star
66

project-error-handling

Error handling project group
264
star
67

atom-ide-rust

Rust IDE support for Atom, powered by the Rust Analyzer or Rust Language Server
JavaScript
259
star
68

stacker

Manual segmented stacks for Rust
Rust
252
star
69

a-mir-formality

a model of MIR and the Rust type/trait system
Rust
245
star
70

cmake-rs

Rust build dependency for running cmake
Rust
241
star
71

edition-guide

A guide to changes between various editions of Rust
238
star
72

getopts

The getopts repo maintained by the rust-lang project
Rust
229
star
73

annotate-snippets-rs

Library for snippet annotations
Rust
223
star
74

rust-roadmap-2017

Tracking Rust's roadmap
215
star
75

areweasyncyet.rs

Are we async yet?
Rust
211
star
76

rust-playpen

A web interface for running Rust code
Rust
208
star
77

wg-allocators

Home of the Allocators working group: Paving a path for a standard set of allocator traits to be used in collections!
199
star
78

rustc-demangle

Rust symbol demangling
Rust
196
star
79

lang-team

Home of the Rust lang team
JavaScript
191
star
80

highfive

Github hooks to provide an encouraging atmosphere for new contributors
Python
185
star
81

ferris-says

A Rust flavored implementation of `cowsay`
Rust
182
star
82

rust-guidelines

This repository has moved
179
star
83

cargo-bisect-rustc

Bisects rustc, either nightlies or CI artifacts
Rust
177
star
84

rustwide

Execute your code on the Rust ecosystem.
Rust
177
star
85

triagebot

Automation/tooling for Rust spaces
Rust
162
star
86

rfcbot-rs

Coordinates asynchronous decision making on Rust repositories. Status of tracked issues and PRs can be viewed at https://rfcbot.rs.
Rust
157
star
87

prev.rust-lang.org

The previous Rust website. The current website's code is at https://github.com/rust-lang/www.rust-lang.org.
HTML
153
star
88

pkg-config-rs

Build library for invoking pkg-config for Rust
Rust
147
star
89

thanks

Celebrate Rust contributors.
Rust
146
star
90

rustc-reading-club

Rust Code Reading Clubs
141
star
91

simpleinfra

Rust Infrastructure automation
HCL
140
star
92

gll

GLL parsing framework.
Rust
137
star
93

ena

An implementation of union-find / congruence-closure in Rust. Extracted from rustc for independent experimentation.
Rust
131
star
94

wg-cargo-std-aware

Repo for working on "std aware cargo"
130
star
95

rust-memory-model

Collecting examples and information to help design a memory model for Rust.
Python
125
star
96

rust-artwork

Official artwork for the Rust project.
122
star
97

libs-team

The home of the library team
Rust
107
star
98

google-summer-of-code

Rust project ideas for Google Summer of Code
105
star
99

rustup-components-history

Rustup package status history
Rust
102
star
100

wg-grammar

Where the work of WG-grammar, aiming to provide a canonical grammar for Rust, resides
Rust
101
star