Skip to content

Commit

Permalink
Add test for systemd instantiated units
Browse files Browse the repository at this point in the history
  • Loading branch information
sohankunkerkar committed Mar 24, 2020
1 parent 497e779 commit 938b27e
Showing 1 changed file with 61 additions and 0 deletions.
61 changes: 61 additions & 0 deletions mantle/kola/tests/ignition/units.go
@@ -0,0 +1,61 @@
// Copyright 2020 Red Hat
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package ignition

import (
"github.com/coreos/mantle/kola/cluster"
"github.com/coreos/mantle/kola/register"
"github.com/coreos/mantle/platform/conf"
)

func init() {
register.RegisterTest(&register.Test{
Name: "coreos.ignition.instantiated.enable-service",
Run: enableSystemdInstantiatedService,
ClusterSize: 1,
UserDataV3: conf.Ignition(`{
"ignition": {"version": "3.0.0"},
"systemd": {
"units": [{
"name": "echo@.service",
"contents": "[Unit]\nDescription=f\n[Service]\nType=oneshot\nExecStart=/bin/echo %i\nRemainAfterExit=yes\n[Install]\nWantedBy=multi-user.target\n"
},
{
"enabled": true,
"name": "echo@bar.service"
},
{
"enabled": true,
"name": "echo@foo.service"
}]
}
}`),
// Enabling systemd instantiated services doesn't support
// in a given system if the version of systemd is older than
// 240. RHCOS deosn't support this feature currently because
// its running an older version (v239) of systemd.
ExcludeDistros: []string{"rhcos"},
})
}

func enableSystemdInstantiatedService(c cluster.TestCluster) {
m := c.Machines()[0]
// MustSSH function will throw an error if the exit code
// of the command is anything other than 0.
c.MustSSH(m, "systemctl -q is-active echo@foo.service")
c.MustSSH(m, "systemctl -q is-active echo@bar.service")
c.MustSSH(m, "systemctl -q is-enabled echo@foo.service")
c.MustSSH(m, "systemctl -q is-enabled echo@bar.service")
}

0 comments on commit 938b27e

Please sign in to comment.