docs: fix README.md and add HACKING.md
Add a HACKING.md document detailing how to get started and test rpm-ostree using the vagrant box. Fix the CONTRIBUTING.md link and add a link to HACKING.md in README.md. Closes: #344 Approved by: cgwalters
This commit is contained in:
parent
9587ab6597
commit
fdbe28b964
53
HACKING.md
Normal file
53
HACKING.md
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
The easiest way to get started hacking on `rpm-ostree` is to
|
||||||
|
use the vagrant machine. This is also the set up used for
|
||||||
|
our integration tests.
|
||||||
|
|
||||||
|
One-time setup
|
||||||
|
==============
|
||||||
|
|
||||||
|
Starting the vagrant machine is as easy as:
|
||||||
|
|
||||||
|
```
|
||||||
|
host$ vagrant up
|
||||||
|
host$ vagrant ssh
|
||||||
|
```
|
||||||
|
|
||||||
|
The VM for now uses the official
|
||||||
|
[centos/atomic-host](https://atlas.hashicorp.com/centos/boxes/atomic-host)
|
||||||
|
box. However, because `rpm-ostree` is tightly coupled with
|
||||||
|
other projects such as `ostree` and `libhif`, the code in
|
||||||
|
`HEAD` may require a more recent version than available in
|
||||||
|
the latest official box.
|
||||||
|
|
||||||
|
For this reason, you may want to rebase the VM onto the
|
||||||
|
[CentOS Atomic Continuous](https://ci.centos.org/job/atomic-rdgo-centos7/)
|
||||||
|
stream, which will contain the latest `HEAD` versions of
|
||||||
|
these dependencies (normally within the hour). To rebase,
|
||||||
|
simply do:
|
||||||
|
|
||||||
|
```
|
||||||
|
vm$ sudo rpm-ostree rebase centos-atomic-continuous:centos-atomic-host/7/x86_64/devel/continuous
|
||||||
|
vm$ sudo systemctl reboot
|
||||||
|
```
|
||||||
|
|
||||||
|
If you need to test your code with custom `ostree` or
|
||||||
|
`libhif` builds, you have no choice for now other than
|
||||||
|
making your own tree (and yum repo for use by the build
|
||||||
|
container). We're hoping to improve this workflow soon.
|
||||||
|
|
||||||
|
Hacking
|
||||||
|
=======
|
||||||
|
|
||||||
|
The `make vmbuild` command will automatically sync the
|
||||||
|
current files to the VM, build `rpm-ostree` and install it
|
||||||
|
into a new deployment, and finally reboot the VM to use it.
|
||||||
|
|
||||||
|
For convenience, the `make vmshell` command does the same
|
||||||
|
but additionally places you in a shell, ready to test your
|
||||||
|
changes.
|
||||||
|
|
||||||
|
Testing
|
||||||
|
=======
|
||||||
|
|
||||||
|
The `make vmcheck` command performs the same task as `make
|
||||||
|
vmbuild`, but additionally starts the integration testsuite.
|
@ -68,8 +68,13 @@ More documentation
|
|||||||
|
|
||||||
New! See the docs online at [Read The Docs (rpm-ostree)](https://rpm-ostree.readthedocs.org/en/latest/ )
|
New! See the docs online at [Read The Docs (rpm-ostree)](https://rpm-ostree.readthedocs.org/en/latest/ )
|
||||||
|
|
||||||
|
Hacking
|
||||||
|
-------
|
||||||
|
|
||||||
|
See [Hacking](HACKING.md).
|
||||||
|
|
||||||
Contributing
|
Contributing
|
||||||
------------
|
------------
|
||||||
|
|
||||||
See [Contributing](CONTRIBUTING.md).
|
See [Contributing](docs/CONTRIBUTING.md).
|
||||||
|
|
||||||
|
2
Vagrantfile
vendored
2
Vagrantfile
vendored
@ -1,6 +1,6 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
|
|
||||||
# See `tests/vmcheck/README.md` for more information on this.
|
# See `HACKING.md` for more information on this.
|
||||||
|
|
||||||
Vagrant.configure(2) do |config|
|
Vagrant.configure(2) do |config|
|
||||||
config.vm.box = "centos/atomic-host"
|
config.vm.box = "centos/atomic-host"
|
||||||
|
Loading…
Reference in New Issue
Block a user