2014-10-17 15:36:22 -07:00
|
|
|
/*
|
|
|
|
Copyright 2014 CoreOS, Inc.
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2014-09-21 19:22:13 -07:00
|
|
|
package system
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"reflect"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/coreos/coreos-cloudinit/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
func testReadConfig(config string) func() (io.Reader, error) {
|
|
|
|
return func() (io.Reader, error) {
|
|
|
|
return strings.NewReader(config), nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUpdateUnits(t *testing.T) {
|
|
|
|
for _, tt := range []struct {
|
|
|
|
config config.Update
|
|
|
|
units []Unit
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
config: config.Update{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{Group: "master", Server: "http://foo.com"},
|
2014-09-21 19:22:38 -07:00
|
|
|
units: []Unit{{config.Unit{
|
2014-09-21 19:22:13 -07:00
|
|
|
Name: "update-engine.service",
|
|
|
|
Command: "restart",
|
2014-09-21 19:22:38 -07:00
|
|
|
}}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "best-effort"},
|
2014-09-21 19:22:38 -07:00
|
|
|
units: []Unit{{config.Unit{
|
2014-09-21 19:22:13 -07:00
|
|
|
Name: "locksmithd.service",
|
|
|
|
Command: "restart",
|
|
|
|
Runtime: true,
|
2014-09-21 19:22:38 -07:00
|
|
|
}}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "etcd-lock"},
|
2014-09-21 19:22:38 -07:00
|
|
|
units: []Unit{{config.Unit{
|
2014-09-21 19:22:13 -07:00
|
|
|
Name: "locksmithd.service",
|
|
|
|
Command: "restart",
|
|
|
|
Runtime: true,
|
2014-09-21 19:22:38 -07:00
|
|
|
}}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "reboot"},
|
2014-09-21 19:22:38 -07:00
|
|
|
units: []Unit{{config.Unit{
|
2014-09-21 19:22:13 -07:00
|
|
|
Name: "locksmithd.service",
|
|
|
|
Command: "restart",
|
|
|
|
Runtime: true,
|
2014-09-21 19:22:38 -07:00
|
|
|
}}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
2014-11-21 10:41:03 -08:00
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "off"},
|
|
|
|
units: []Unit{{config.Unit{
|
|
|
|
Name: "locksmithd.service",
|
|
|
|
Command: "stop",
|
|
|
|
Runtime: true,
|
|
|
|
Mask: true,
|
|
|
|
}}},
|
|
|
|
},
|
2014-09-21 19:22:13 -07:00
|
|
|
} {
|
2014-10-23 11:44:15 -07:00
|
|
|
units := Update{Update: tt.config, ReadConfig: testReadConfig("")}.Units()
|
2014-09-21 19:22:13 -07:00
|
|
|
if !reflect.DeepEqual(tt.units, units) {
|
|
|
|
t.Errorf("bad units (%q): want %#v, got %#v", tt.config, tt.units, units)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUpdateFile(t *testing.T) {
|
|
|
|
for _, tt := range []struct {
|
|
|
|
config config.Update
|
|
|
|
orig string
|
|
|
|
file *File
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
config: config.Update{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "wizzlewazzle"},
|
2014-12-20 23:26:05 -08:00
|
|
|
err: &config.ErrorValid{Value: "wizzlewazzle", Field: "RebootStrategy", Valid: "^(best-effort|etcd-lock|reboot|off)$"},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{Group: "master", Server: "http://foo.com"},
|
2014-09-21 19:22:27 -07:00
|
|
|
file: &File{config.File{
|
2014-09-21 19:22:13 -07:00
|
|
|
Content: "GROUP=master\nSERVER=http://foo.com\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
2014-09-21 19:22:27 -07:00
|
|
|
}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "best-effort"},
|
2014-09-21 19:22:27 -07:00
|
|
|
file: &File{config.File{
|
2014-09-21 19:22:13 -07:00
|
|
|
Content: "REBOOT_STRATEGY=best-effort\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
2014-09-21 19:22:27 -07:00
|
|
|
}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "etcd-lock"},
|
2014-09-21 19:22:27 -07:00
|
|
|
file: &File{config.File{
|
2014-09-21 19:22:13 -07:00
|
|
|
Content: "REBOOT_STRATEGY=etcd-lock\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
2014-09-21 19:22:27 -07:00
|
|
|
}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "reboot"},
|
2014-09-21 19:22:27 -07:00
|
|
|
file: &File{config.File{
|
2014-09-21 19:22:13 -07:00
|
|
|
Content: "REBOOT_STRATEGY=reboot\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
2014-09-21 19:22:27 -07:00
|
|
|
}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
2014-11-21 10:41:03 -08:00
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "off"},
|
|
|
|
file: &File{config.File{
|
|
|
|
Content: "REBOOT_STRATEGY=off\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
|
|
|
}},
|
|
|
|
},
|
2014-09-21 19:22:13 -07:00
|
|
|
{
|
|
|
|
config: config.Update{RebootStrategy: "etcd-lock"},
|
|
|
|
orig: "SERVER=https://example.com\nGROUP=thegroupc\nREBOOT_STRATEGY=awesome",
|
2014-09-21 19:22:27 -07:00
|
|
|
file: &File{config.File{
|
2014-09-21 19:22:13 -07:00
|
|
|
Content: "SERVER=https://example.com\nGROUP=thegroupc\nREBOOT_STRATEGY=etcd-lock\n",
|
|
|
|
Path: "etc/coreos/update.conf",
|
|
|
|
RawFilePermissions: "0644",
|
2014-09-21 19:22:27 -07:00
|
|
|
}},
|
2014-09-21 19:22:13 -07:00
|
|
|
},
|
|
|
|
} {
|
2014-10-23 11:44:15 -07:00
|
|
|
file, err := Update{Update: tt.config, ReadConfig: testReadConfig(tt.orig)}.File()
|
2014-09-21 19:22:13 -07:00
|
|
|
if !reflect.DeepEqual(tt.err, err) {
|
|
|
|
t.Errorf("bad error (%q): want %q, got %q", tt.config, tt.err, err)
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(tt.file, file) {
|
|
|
|
t.Errorf("bad units (%q): want %#v, got %#v", tt.config, tt.file, file)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|