package cmd import ( "bytes" "io/ioutil" "os" "github.com/jenkins-zh/jenkins-cli/client" "github.com/golang/mock/gomock" "github.com/jenkins-zh/jenkins-cli/mock/mhttp" . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" ) var _ = Describe("job log command", func() { var ( ctrl *gomock.Controller roundTripper *mhttp.MockRoundTripper rootURL string username string token string ) BeforeEach(func() { ctrl = gomock.NewController(GinkgoT()) roundTripper = mhttp.NewMockRoundTripper(ctrl) jobLogOption.RoundTripper = roundTripper rootCmd.SetArgs([]string{}) rootOptions.Jenkins = "" rootOptions.ConfigFile = "test.yaml" rootURL = "http://localhost:8080/jenkins" username = "admin" token = "111e3a2f0231198855dceaff96f20540a9" }) AfterEach(func() { rootCmd.SetArgs([]string{}) os.Remove(rootOptions.ConfigFile) rootOptions.ConfigFile = "" ctrl.Finish() }) Context("basic cases, need RoundTripper", func() { It("output the last build log", func() { data, err := GenerateSampleConfig() Expect(err).To(BeNil()) err = ioutil.WriteFile(rootOptions.ConfigFile, data, 0664) Expect(err).To(BeNil()) jobName := "fake" client.PrepareForGetBuild(roundTripper, rootURL, jobName, -1, username, token) client.PrepareForJobLog(roundTripper, rootURL, jobName, -1, username, token) rootCmd.SetArgs([]string{"job", "log", jobName}) buf := new(bytes.Buffer) rootCmd.SetOutput(buf) _, err = rootCmd.ExecuteC() Expect(err).To(BeNil()) Expect(buf.String()).To(Equal("Current build number: 0\nCurrent build url: \nfake log")) }) }) })