github.com/hernad/nomad@v1.6.112/e2e/periodic/periodic.go (about) 1 // Copyright (c) HashiCorp, Inc. 2 // SPDX-License-Identifier: MPL-2.0 3 4 package periodic 5 6 import ( 7 "fmt" 8 9 "github.com/hernad/nomad/e2e/e2eutil" 10 "github.com/hernad/nomad/e2e/framework" 11 "github.com/hernad/nomad/helper/uuid" 12 "github.com/hernad/nomad/testutil" 13 "github.com/stretchr/testify/require" 14 ) 15 16 type PeriodicTest struct { 17 framework.TC 18 jobIDs []string 19 } 20 21 func init() { 22 framework.AddSuites(&framework.TestSuite{ 23 Component: "Periodic", 24 CanRunLocal: true, 25 Cases: []framework.TestCase{ 26 new(PeriodicTest), 27 }, 28 }) 29 } 30 31 func (tc *PeriodicTest) BeforeAll(f *framework.F) { 32 e2eutil.WaitForLeader(f.T(), tc.Nomad()) 33 } 34 35 func (tc *PeriodicTest) AfterEach(f *framework.F) { 36 nomadClient := tc.Nomad() 37 j := nomadClient.Jobs() 38 39 for _, id := range tc.jobIDs { 40 j.Deregister(id, true, nil) 41 } 42 _, err := e2eutil.Command("nomad", "system", "gc") 43 f.NoError(err) 44 } 45 46 func (tc *PeriodicTest) TestPeriodicDispatch_Basic(f *framework.F) { 47 t := f.T() 48 49 uuid := uuid.Generate() 50 jobID := fmt.Sprintf("periodicjob-%s", uuid[0:8]) 51 tc.jobIDs = append(tc.jobIDs, jobID) 52 53 // register job 54 require.NoError(t, e2eutil.Register(jobID, "periodic/input/simple.nomad")) 55 56 // force dispatch 57 require.NoError(t, e2eutil.PeriodicForce(jobID)) 58 59 testutil.WaitForResult(func() (bool, error) { 60 children, err := e2eutil.PreviouslyLaunched(jobID) 61 if err != nil { 62 return false, err 63 } 64 65 for _, c := range children { 66 if c["Status"] == "dead" { 67 return true, nil 68 } 69 } 70 return false, fmt.Errorf("expected periodic job to be dead") 71 }, func(err error) { 72 require.NoError(t, err) 73 }) 74 75 // Assert there are no pending children 76 summary, err := e2eutil.ChildrenJobSummary(jobID) 77 require.NoError(t, err) 78 require.Len(t, summary, 1) 79 require.Equal(t, summary[0]["Pending"], "0") 80 require.Equal(t, summary[0]["Running"], "0") 81 require.Equal(t, summary[0]["Dead"], "1") 82 }