Env is environment, Config is ours. Provides centralised access to system facts (OS, ARCH, hostname, user, directories, timestamps) via string key lookup, populated once at package init. Keys: OS, ARCH, GO, DS, PS, HOSTNAME, USER, PID, NUM_CPU, DIR_HOME, DIR_CONFIG, DIR_CACHE, DIR_DATA, DIR_TMP, DIR_CWD, DIR_DOWNLOADS, DIR_CODE, CORE_START. 17 tests covering all keys + unknown key + Core instance accessor. Co-Authored-By: Virgil <virgil@lethean.io>
99 lines
2.1 KiB
Go
99 lines
2.1 KiB
Go
// SPDX-License-Identifier: EUPL-1.2
|
|
|
|
package core_test
|
|
|
|
import (
|
|
"os"
|
|
"runtime"
|
|
"testing"
|
|
"time"
|
|
|
|
core "dappco.re/go/core"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestEnv_OS(t *testing.T) {
|
|
assert.Equal(t, runtime.GOOS, core.Env("OS"))
|
|
}
|
|
|
|
func TestEnv_ARCH(t *testing.T) {
|
|
assert.Equal(t, runtime.GOARCH, core.Env("ARCH"))
|
|
}
|
|
|
|
func TestEnv_GO(t *testing.T) {
|
|
assert.Equal(t, runtime.Version(), core.Env("GO"))
|
|
}
|
|
|
|
func TestEnv_DS(t *testing.T) {
|
|
assert.Equal(t, string(os.PathSeparator), core.Env("DS"))
|
|
}
|
|
|
|
func TestEnv_PS(t *testing.T) {
|
|
assert.Equal(t, string(os.PathListSeparator), core.Env("PS"))
|
|
}
|
|
|
|
func TestEnv_DIR_HOME(t *testing.T) {
|
|
home, err := os.UserHomeDir()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, home, core.Env("DIR_HOME"))
|
|
}
|
|
|
|
func TestEnv_DIR_TMP(t *testing.T) {
|
|
assert.Equal(t, os.TempDir(), core.Env("DIR_TMP"))
|
|
}
|
|
|
|
func TestEnv_DIR_CONFIG(t *testing.T) {
|
|
cfg, err := os.UserConfigDir()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, cfg, core.Env("DIR_CONFIG"))
|
|
}
|
|
|
|
func TestEnv_DIR_CACHE(t *testing.T) {
|
|
cache, err := os.UserCacheDir()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, cache, core.Env("DIR_CACHE"))
|
|
}
|
|
|
|
func TestEnv_HOSTNAME(t *testing.T) {
|
|
hostname, err := os.Hostname()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, hostname, core.Env("HOSTNAME"))
|
|
}
|
|
|
|
func TestEnv_USER(t *testing.T) {
|
|
assert.NotEmpty(t, core.Env("USER"))
|
|
}
|
|
|
|
func TestEnv_PID(t *testing.T) {
|
|
assert.NotEmpty(t, core.Env("PID"))
|
|
}
|
|
|
|
func TestEnv_NUM_CPU(t *testing.T) {
|
|
assert.NotEmpty(t, core.Env("NUM_CPU"))
|
|
}
|
|
|
|
func TestEnv_CORE_START(t *testing.T) {
|
|
ts := core.Env("CORE_START")
|
|
require.NotEmpty(t, ts)
|
|
_, err := time.Parse(time.RFC3339, ts)
|
|
assert.NoError(t, err, "CORE_START should be valid RFC3339")
|
|
}
|
|
|
|
func TestEnv_Unknown(t *testing.T) {
|
|
assert.Equal(t, "", core.Env("NOPE"))
|
|
}
|
|
|
|
func TestEnv_CoreInstance(t *testing.T) {
|
|
c := core.New()
|
|
assert.Equal(t, core.Env("OS"), c.Env("OS"))
|
|
assert.Equal(t, core.Env("DIR_HOME"), c.Env("DIR_HOME"))
|
|
}
|
|
|
|
func TestEnvKeys(t *testing.T) {
|
|
keys := core.EnvKeys()
|
|
assert.NotEmpty(t, keys)
|
|
assert.Contains(t, keys, "OS")
|
|
assert.Contains(t, keys, "DIR_HOME")
|
|
assert.Contains(t, keys, "CORE_START")
|
|
}
|