diff --git a/.gitignore b/.gitignore index 8fde131..334490d 100644 --- a/.gitignore +++ b/.gitignore @@ -18,9 +18,10 @@ _cgo_gotypes.go _cgo_export.* _testmain.go +*.test *.exe # IntelliJ files .idea -*.iml \ No newline at end of file +*.iml diff --git a/README.md b/README.md index df2d76d..d396b09 100644 --- a/README.md +++ b/README.md @@ -3,6 +3,8 @@ gocommon Common Go library for Joyent's Triton and Manta. +[![wercker status](https://app.wercker.com/status/2f63bf7f68bfdd46b979abad19c0bee0/s/master "wercker status")](https://app.wercker.com/project/byKey/2f63bf7f68bfdd46b979abad19c0bee0) + ## Installation Use `go-get` to install gocommon. @@ -70,7 +72,20 @@ upstream git@github.com:joyent/gocommon.git (push) ### Run Tests +The library needs values for the `SDC_URL`, `MANTA_URL`, `MANTA_KEY_ID` and `SDC_KEY_ID` environment variables even though the tests are run locally. You can generate a temporary key and use its fingerprint for tests without adding the key to your Triton Cloud account. + ``` +# create a temporary key +ssh-keygen -b 2048 -C "Testing Key" -f /tmp/id_rsa -t rsa -P "" + +# set up environment +# note: leave the -E md5 argument off on older ssh-keygen +export KEY_ID=$(ssh-keygen -E md5 -lf /tmp/id_rsa | awk -F' ' '{print $2}' | cut -d':' -f2-) +export SDC_KEY_ID=${KEY_ID} +export MANTA_KEY_ID=${KEY_ID} +export SDC_URL=https://us-east-1.api.joyent.com +export MANTA_URL=https://us-east.manta.joyent.com + cd ${GOPATH}/src/github.com/joyent/gocommon go test ./... ``` diff --git a/errors/errors.go b/errors/errors.go index f906e2c..4c641ca 100644 --- a/errors/errors.go +++ b/errors/errors.go @@ -29,7 +29,7 @@ const ( RequestTooLargeError = Code("RequestTooLarge") RequestMovedError = Code("RequestMoved") ResourceNotFoundError = Code("ResourceNotFound") - UnknownErrorError = Code("UnkownError") + UnknownErrorError = Code("UnknownError") ) // Error instances store an optional error cause. diff --git a/http/client_test.go b/http/client_test.go index 55d2f7e..53c8d02 100644 --- a/http/client_test.go +++ b/http/client_test.go @@ -10,6 +10,7 @@ import ( httpsuite "github.com/joyent/gocommon/testing" "github.com/joyent/gosign/auth" + "github.com/julienschmidt/httprouter" ) const ( @@ -66,7 +67,7 @@ func (s *LoopingHTTPSuite) SetUpSuite(c *gc.C) { func (s *LoopingHTTPSuite) setupLoopbackRequest() (*http.Header, chan string, *Client) { var headers http.Header bodyChan := make(chan string, 1) - handler := func(resp http.ResponseWriter, req *http.Request) { + handler := func(resp http.ResponseWriter, req *http.Request, _ httprouter.Params) { headers = req.Header bodyBytes, _ := ioutil.ReadAll(req.Body) req.Body.Close() @@ -75,7 +76,7 @@ func (s *LoopingHTTPSuite) setupLoopbackRequest() (*http.Header, chan string, *C resp.WriteHeader(http.StatusNoContent) resp.Write([]byte{}) } - s.Mux.HandleFunc("/", handler) + s.Mux.POST("/", handler) client := New(s.creds, "", nil) return &headers, bodyChan, client @@ -89,8 +90,14 @@ type HTTPSClientTestSuite struct { LoopingHTTPSuite } +func newTLSsuite() *HTTPSClientTestSuite { + suite := &HTTPSClientTestSuite{} + suite.UseTLS = true + return suite +} + var _ = gc.Suite(&HTTPClientTestSuite{}) -var _ = gc.Suite(&HTTPSClientTestSuite{}) +var _ = gc.Suite(newTLSsuite()) func (s *HTTPClientTestSuite) assertHeaderValues(c *gc.C, apiVersion string) { emptyHeaders := http.Header{} diff --git a/testing/httpsuite_test.go b/testing/httpsuite_test.go index 60e31e1..c93e723 100644 --- a/testing/httpsuite_test.go +++ b/testing/httpsuite_test.go @@ -11,6 +11,7 @@ import ( "testing" jt "github.com/joyent/gocommon/testing" + "github.com/julienschmidt/httprouter" ) type HTTPTestSuite struct { @@ -28,16 +29,14 @@ func Test(t *testing.T) { var _ = gc.Suite(&HTTPTestSuite{}) var _ = gc.Suite(&HTTPSTestSuite{jt.HTTPSuite{UseTLS: true}}) -type HelloHandler struct{} - -func (h *HelloHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { +func HelloHandler(w http.ResponseWriter, r *http.Request, _ httprouter.Params) { w.Header().Set("Content-Type", "text/plain") w.WriteHeader(200) w.Write([]byte("Hello World\n")) } func (s *HTTPTestSuite) TestHelloWorld(c *gc.C) { - s.Mux.Handle("/", &HelloHandler{}) + s.Mux.GET("/", HelloHandler) response, err := http.Get(s.Server.URL) c.Check(err, gc.IsNil) content, err := ioutil.ReadAll(response.Body) @@ -49,7 +48,7 @@ func (s *HTTPTestSuite) TestHelloWorld(c *gc.C) { } func (s *HTTPSTestSuite) TestHelloWorldWithTLS(c *gc.C) { - s.Mux.Handle("/", &HelloHandler{}) + s.Mux.GET("/", HelloHandler) c.Check(s.Server.URL[:8], gc.Equals, "https://") response, err := http.Get(s.Server.URL) // Default http.Get fails because the cert is self-signed diff --git a/wercker.yml b/wercker.yml new file mode 100644 index 0000000..563acf6 --- /dev/null +++ b/wercker.yml @@ -0,0 +1,40 @@ +box: golang + +build: + steps: + # Sets the go workspace and places you package + # at the right place in the workspace tree + - setup-go-workspace: + package-dir: github.com/joyent/gocommon + + # Gets the dependencies + - script: + name: go get + code: | + go get -v -t ./... + + # Build the project + - script: + name: go build + code: | + go build ./... + + - script: + name: make a new key for testing + code: | + ssh-keygen -b 2048 \ + -C "Testing Key" \ + -f /root/.ssh/id_rsa \ + -t rsa \ + -P "" + + # Test the project + - script: + name: go test + code: | + export KEY_ID=$(ssh-keygen -lf /root/.ssh/id_rsa | awk -F' ' '{print $2}' | cut -d':' -f2-) + export SDC_KEY_ID=${KEY_ID} + export MANTA_KEY_ID=${KEY_ID} + export SDC_URL=https://us-east-1.api.joyent.com + export MANTA_URL=https://us-east.manta.joyent.com + go test ./...