func checkFileHasContents(c *gc.C, stor storage.StorageReader, name string, contents []byte, attempt utils.AttemptStrategy) { r, err := storage.GetWithRetry(stor, name, attempt) c.Assert(err, gc.IsNil) c.Check(r, gc.NotNil) defer r.Close() data, err := ioutil.ReadAll(r) c.Check(err, gc.IsNil) c.Check(data, gc.DeepEquals, contents) url, err := stor.URL(name) c.Assert(err, gc.IsNil) var resp *http.Response for a := attempt.Start(); a.Next(); { resp, err = utils.GetValidatingHTTPClient().Get(url) c.Assert(err, gc.IsNil) if resp.StatusCode != 404 { break } c.Logf("get retrying after earlier get succeeded. *sigh*.") } c.Assert(err, gc.IsNil) data, err = ioutil.ReadAll(resp.Body) c.Assert(err, gc.IsNil) defer resp.Body.Close() c.Assert(resp.StatusCode, gc.Equals, 200, gc.Commentf("error response: %s", data)) c.Check(data, gc.DeepEquals, contents) }
// downloadToolsRaw downloads the supplied tools and returns the raw bytes. func downloadToolsRaw(c *gc.C, t *coretools.Tools) []byte { resp, err := utils.GetValidatingHTTPClient().Get(t.URL) c.Assert(err, gc.IsNil) defer resp.Body.Close() c.Assert(resp.StatusCode, gc.Equals, http.StatusOK) var buf bytes.Buffer _, err = io.Copy(&buf, resp.Body) c.Assert(err, gc.IsNil) return buf.Bytes() }
// downloadTools downloads the supplied tools and extracts them into a // new directory. func downloadTools(c *gc.C, t *coretools.Tools) string { resp, err := utils.GetValidatingHTTPClient().Get(t.URL) c.Assert(err, gc.IsNil) defer resp.Body.Close() cmd := exec.Command("tar", "xz") cmd.Dir = c.MkDir() cmd.Stdin = resp.Body out, err := cmd.CombinedOutput() c.Assert(err, gc.IsNil, gc.Commentf(string(out))) return cmd.Dir }
// PrimeTools sets up the current version of the tools to vers and // makes sure that they're available in the dataDir. func PrimeTools(c *gc.C, stor storage.Storage, dataDir string, vers version.Binary) *coretools.Tools { err := os.RemoveAll(filepath.Join(dataDir, "tools")) c.Assert(err, gc.IsNil) agentTools, err := uploadFakeToolsVersion(stor, vers) c.Assert(err, gc.IsNil) resp, err := utils.GetValidatingHTTPClient().Get(agentTools.URL) c.Assert(err, gc.IsNil) defer resp.Body.Close() err = agenttools.UnpackTools(dataDir, agentTools, resp.Body) c.Assert(err, gc.IsNil) return agentTools }
// copyOneToolsPackage copies one tool from the source to the target. func copyOneToolsPackage(tool *coretools.Tools, dest storage.Storage) error { toolsName := envtools.StorageName(tool.Version) logger.Infof("copying %v", toolsName) resp, err := utils.GetValidatingHTTPClient().Get(tool.URL) if err != nil { return err } buf := &bytes.Buffer{} srcFile := resp.Body defer srcFile.Close() tool.SHA256, tool.Size, err = utils.ReadSHA256(io.TeeReader(srcFile, buf)) if err != nil { return err } sizeInKB := (tool.Size + 512) / 1024 logger.Infof("downloaded %v (%dkB), uploading", toolsName, sizeInKB) logger.Infof("download %dkB, uploading", sizeInKB) return dest.Put(toolsName, buf, tool.Size) }
func (s *httpSuite) TestValidatingClientFails(c *gc.C) { client := utils.GetValidatingHTTPClient() _, err := client.Get(s.Server.URL) c.Assert(err, gc.ErrorMatches, "(.|\n)*x509: certificate signed by unknown authority") }
func (s *httpSuite) TestValidatingClientGetter(c *gc.C) { client1 := utils.GetValidatingHTTPClient() client2 := utils.GetHTTPClient(utils.VerifySSLHostnames) c.Check(client1, gc.Equals, client2) }
// Client returns a storage object that will talk to the // storage server at the given network address (see Serve) func Client(addr string) storage.Storage { return &localStorage{ addr: addr, client: utils.GetValidatingHTTPClient(), } }