summaryrefslogtreecommitdiffstats
path: root/cmd/platform
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-11-17 08:27:26 -0600
committerenahum <nahumhbl@gmail.com>2017-11-17 11:27:26 -0300
commit065d8e97313b9c8ffad37862665186668c88499f (patch)
treee59810898b9bfab1e5591a72373330b0a4454dc3 /cmd/platform
parenteb1a00ef5f93b19c2d49b26de057ee2c51c09e45 (diff)
downloadchat-065d8e97313b9c8ffad37862665186668c88499f.tar.gz
chat-065d8e97313b9c8ffad37862665186668c88499f.tar.bz2
chat-065d8e97313b9c8ffad37862665186668c88499f.zip
make `config validate` exit with non-zero code on failure (#7855)
Diffstat (limited to 'cmd/platform')
-rw-r--r--cmd/platform/config.go21
-rw-r--r--cmd/platform/config_test.go3
-rw-r--r--cmd/platform/mattermost_test.go11
3 files changed, 12 insertions, 23 deletions
diff --git a/cmd/platform/config.go b/cmd/platform/config.go
index 6a3df0ade..0b3f26ee0 100644
--- a/cmd/platform/config.go
+++ b/cmd/platform/config.go
@@ -20,7 +20,8 @@ var configCmd = &cobra.Command{
var validateConfigCmd = &cobra.Command{
Use: "validate",
Short: "Validate config file",
- Run: configValidateCmdF,
+ Long: "If the config file is valid, this command will output a success message and have a zero exit code. If it is invalid, this command will output an error and have a non-zero exit code.",
+ RunE: configValidateCmdF,
}
func init() {
@@ -29,39 +30,35 @@ func init() {
)
}
-func configValidateCmdF(cmd *cobra.Command, args []string) {
+func configValidateCmdF(cmd *cobra.Command, args []string) error {
utils.TranslationsPreInit()
filePath, err := cmd.Flags().GetString("config")
if err != nil {
- CommandPrintErrorln(err)
- return
+ return err
}
filePath = utils.FindConfigFile(filePath)
file, err := os.Open(filePath)
if err != nil {
- CommandPrintErrorln(err)
- return
+ return err
}
decoder := json.NewDecoder(file)
config := model.Config{}
err = decoder.Decode(&config)
if err != nil {
- CommandPrintErrorln(err)
- return
+ return err
}
if _, err := file.Stat(); err != nil {
- CommandPrintErrorln(err)
- return
+ return err
}
if err := config.IsValid(); err != nil {
- CommandPrintErrorln(errors.New(utils.T(err.Id)))
- return
+ return errors.New(utils.T(err.Id))
}
CommandPrettyPrintln("The document is valid")
+ return nil
}
diff --git a/cmd/platform/config_test.go b/cmd/platform/config_test.go
index 781e40de8..f1c09c6f5 100644
--- a/cmd/platform/config_test.go
+++ b/cmd/platform/config_test.go
@@ -25,5 +25,6 @@ func TestConfigValidate(t *testing.T) {
config.SetDefaults()
require.NoError(t, ioutil.WriteFile(path, []byte(config.ToJson()), 0600))
- assert.Contains(t, checkCommand(t, "--config", path, "config", "validate"), "The document is valid")
+ assert.Error(t, runCommand(t, "--config", "foo.json", "config", "validate"))
+ assert.NoError(t, runCommand(t, "--config", path, "config", "validate"))
}
diff --git a/cmd/platform/mattermost_test.go b/cmd/platform/mattermost_test.go
index c7e1f6f2b..eba45801a 100644
--- a/cmd/platform/mattermost_test.go
+++ b/cmd/platform/mattermost_test.go
@@ -4,7 +4,6 @@
package main
import (
- "io"
"io/ioutil"
"os"
"path/filepath"
@@ -25,17 +24,9 @@ func TestConfigFlag(t *testing.T) {
configPath := filepath.Join(dir, "foo.json")
require.NoError(t, ioutil.WriteFile(configPath, []byte(config.ToJson()), 0600))
- os.Mkdir(filepath.Join(dir, "i18n"), 0700)
i18n, ok := utils.FindDir("i18n")
require.True(t, ok)
- en, err := os.Open(filepath.Join(i18n, "en.json"))
- require.NoError(t, err)
- defer en.Close()
- dest, err := os.OpenFile(filepath.Join(dir, "i18n", "en.json"), os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0600)
- require.NoError(t, err)
- defer dest.Close()
- _, err = io.Copy(dest, en)
- require.NoError(t, err)
+ require.NoError(t, utils.CopyDir(i18n, filepath.Join(dir, "i18n")))
prevDir, err := os.Getwd()
require.NoError(t, err)