pulumi/README.md

85 lines
3.5 KiB
Markdown
Raw Normal View History

2017-09-11 22:05:01 +02:00
# Pulumi Fabric
2016-10-09 01:01:25 +02:00
The Pulumi Fabric ("Pulumi") is a framework and toolset for creating reusable cloud services.
If you are learning about Pulumi for the first time, please [visit our docs website](https://docs.pulumi.com/).
2017-10-10 22:40:11 +02:00
## Build Status
2017-10-10 22:41:45 +02:00
| Architecture | Build Status |
| ------------ | ------------ |
| Linux x64 | [![Linux x64 Build Status](https://travis-ci.com/pulumi/pulumi.svg?token=cTUUEgrxaTEGyecqJpDn&branch=master)](https://travis-ci.com/pulumi/pulumi) |
| Windows x64 | [![Windows x64 Build Status](https://ci.appveyor.com/api/projects/status/uqrduw6qnoss7g4i?svg=true&branch=master)](https://ci.appveyor.com/project/pulumi/pulumi) |
2017-10-10 22:40:11 +02:00
2017-02-25 19:46:26 +01:00
## Installing
To install Pulumi from source, simply run:
2017-02-25 19:46:26 +01:00
$ go get -u github.com/pulumi/pulumi
2017-02-25 19:46:26 +01:00
A `GOPATH` must be set. A good default value is `~/go`. In fact, [this is the default in Go 1.8](
https://github.com/golang/go/issues/17262).
This installs the `pulumi` binary to `$GOPATH/bin`.
2017-02-25 19:46:26 +01:00
To do anything interesting with Pulumi, you will need an SDK for your language of choice. Please see
2017-09-11 22:05:01 +02:00
[sdk/README.md](`sdk/`) for information about how to obtain, install, and use such an SDK.
2017-02-25 19:52:01 +01:00
2017-02-25 19:46:26 +01:00
## Development
This section is for Pulumi developers.
2017-02-25 19:46:26 +01:00
### Prerequisites
Pulumi is written in Go, uses Dep for dependency management, and GoMetaLinter for linting:
* [Go](https://golang.org/doc/install): https://golang.org/dl
2017-08-02 03:37:06 +02:00
* [Dep](https://github.com/golang/dep): `$ go get -u github.com/golang/dep/cmd/dep`
* [GoMetaLinter](https://github.com/alecthomas/gometalinter):
2017-08-02 03:37:06 +02:00
- `$ go get -u github.com/alecthomas/gometalinter`
- `$ gometalinter --install`
2017-02-25 19:46:26 +01:00
### Building and Testing
To build Pulumi, ensure `$GOPATH` is set, and clone into a standard Go workspace:
2016-11-23 21:41:30 +01:00
$ git clone git@github.com:pulumi/pulumi $GOPATH/src/github.com/pulumi/pulumi
$ cd $GOPATH/src/github.com/pulumi/pulumi
2016-11-23 21:41:30 +01:00
The first time you build, you must `make configure` to install dependencies and perform other machine setup:
$ make configure
In the future, you can synch dependencies simply by running `dep ensure` explicitly:
2017-05-24 22:25:28 +02:00
2017-08-02 03:37:06 +02:00
$ dep ensure
2017-05-24 22:25:28 +02:00
At this point you can run `make` to build and run tests:
2016-11-23 21:41:30 +01:00
$ make
This installs the `pulumi` binary into `$GOPATH/bin`, which may now be run provided `make` exited successfully.
2016-11-23 21:41:30 +01:00
2017-05-24 22:25:28 +02:00
The Makefile also supports just running tests (`make test`), just running the linter (`make lint`), just running Govet
(`make vet`), and so on. Please just refer to the Makefile for the full list of targets.
2017-02-25 19:52:01 +01:00
### Debugging
2017-01-26 22:50:27 +01:00
The Pulumi tools have extensive logging built in. In fact, we encourage liberal logging in new code, and adding new
2017-01-26 22:50:27 +01:00
logging when debugging problems. This helps to ensure future debugging endeavors benefit from your sleuthing.
All logging is done using Google's [Glog library](https://github.com/golang/glog). It is relatively bare-bones, and
adds basic leveled logging, stack dumping, and other capabilities beyond what Go's built-in logging routines offer.
2017-01-26 22:50:27 +01:00
The `pulumi` command line has two flags that control this logging and that can come in handy when debugging problems.
The `--logtostderr` flag spews directly to stderr, rather than the default of logging to files in your temp directory.
And the `--verbose=n` flag (`-v=n` for short) sets the logging level to `n`. Anything greater than 3 is reserved for
2017-01-26 22:50:27 +01:00
debug-level logging, greater than 5 is going to be quite verbose, and anything beyond 7 is extremely noisy.
For example, the command
$ pulumi eval --logtostderr -v=5
2017-01-26 22:50:27 +01:00
is a pretty standard starting point during debugging that will show a fairly comprehensive trace log of a compilation.