Add usage example
This commit is contained in:
parent
8649c791ea
commit
5bd995a66e
43
README.md
43
README.md
@ -1,12 +1,13 @@
|
|||||||
# go-qemu-kernel
|
# go-qemu-kernel
|
||||||
|
|
||||||
Qemu wrapper for kernel-related CI tasks
|
Qemu wrapper for kernel-related CI tasks. Supports *GNU/Linux* and *macOS*.
|
||||||
|
|
||||||
## Usage
|
Features:
|
||||||
|
* Uses upstream virtualization -- KVM in GNU/Linux and Hypervisor.framework in macOS.
|
||||||
|
* Run files and kernel modules directly from local filesystem. No need to copy byself!
|
||||||
|
* Run commands inside qemu virtual machine at the same way as you run in it locally.
|
||||||
|
|
||||||
TODO
|
## Installation
|
||||||
|
|
||||||
## Development
|
|
||||||
|
|
||||||
$ go get github.com/jollheef/go-qemu-kernel
|
$ go get github.com/jollheef/go-qemu-kernel
|
||||||
|
|
||||||
@ -41,3 +42,35 @@ bionic.img and bionic-vmlinuz will be created in current directory.
|
|||||||
### Run tests
|
### Run tests
|
||||||
|
|
||||||
$ go test -v
|
$ go test -v
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
$ go get github.com/jollheef/go-qemu-kernel
|
||||||
|
|
||||||
|
Minimal example:
|
||||||
|
|
||||||
|
kernel := qemu.Kernel{
|
||||||
|
Name: "Some kernel name",
|
||||||
|
KernelPath: "/path/to/vmlinuz",
|
||||||
|
InitrdPath: "/path/to/initrd", // if required
|
||||||
|
}
|
||||||
|
q, err := qemu.NewQemuSystem(qemu.X86_64, kernel, "/path/to/qcow2")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err = q.Start(); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
defer q.Stop()
|
||||||
|
|
||||||
|
output, err = q.Command("root", "echo Hello, World!")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// output == "Hello, World!\n"
|
||||||
|
|
||||||
|
More information and list of all functions see at go documentation project, or just run locally:
|
||||||
|
|
||||||
|
$ godoc github.com/jollheef/go-qemu-kernel
|
||||||
|
Loading…
Reference in New Issue
Block a user