TrueChartsClone/tests/library/common/addon_vpn_spec.rb

107 lines
3.4 KiB
Ruby

# frozen_string_literal: true
require_relative '../../test_helper'
class Test < ChartTest
@@chart = Chart.new('charts/library/common-test')
describe @@chart.name do
describe 'addon::vpn' do
it 'defaults to disabled' do
deployment = chart.resources(kind: "Deployment").first
containers = deployment["spec"]["template"]["spec"]["containers"]
openvpnContainer = containers.find{ |c| c["name"] == "openvpn" }
wireguardContainer = containers.find{ |c| c["name"] == "wireguard" }
assert_nil(openvpnContainer)
assert_nil(wireguardContainer)
end
it 'openvpn can be enabled' do
values = {
addons: {
vpn: {
type: "openvpn"
}
}
}
chart.value values
deployment = chart.resources(kind: "Deployment").first
containers = deployment["spec"]["template"]["spec"]["containers"]
vpnContainer = containers.find{ |c| c["name"] == "openvpn" }
refute_nil(vpnContainer)
end
it 'wireguard can be enabled' do
values = {
addons: {
vpn: {
type: "wireguard"
}
}
}
chart.value values
deployment = chart.resources(kind: "Deployment").first
containers = deployment["spec"]["template"]["spec"]["containers"]
wireguardContainer = containers.find{ |c| c["name"] == "wireguard" }
refute_nil(wireguardContainer)
end
it 'a openvpn configuration file can be passed' do
values = {
addons: {
vpn: {
type: "openvpn",
configFile: {
enabled: true,
hostPath: "/test.conf"
}
}
}
}
chart.value values
deployment = chart.resources(kind: "Deployment").first
secret = chart.resources(kind: "Secret").first
containers = deployment["spec"]["template"]["spec"]["containers"]
volumes = deployment["spec"]["template"]["spec"]["volumes"]
vpnContainer = containers.find{ |c| c["name"] == "openvpn" }
# Make sure the deployKey volumeMount is present in the sidecar container
vpnconfigVolumeMount = vpnContainer["volumeMounts"].find { |v| v["name"] == "vpnconfig"}
refute_nil(vpnconfigVolumeMount)
assert_equal("/vpn/vpn.conf", vpnconfigVolumeMount["mountPath"])
end
it 'a wireguard configuration file can be passed' do
values = {
addons: {
vpn: {
type: "wireguard",
configFile: {
enabled: true,
hostPath: "/test.conf"
}
}
}
}
chart.value values
deployment = chart.resources(kind: "Deployment").first
secret = chart.resources(kind: "Secret").first
containers = deployment["spec"]["template"]["spec"]["containers"]
volumes = deployment["spec"]["template"]["spec"]["volumes"]
vpnContainer = containers.find{ |c| c["name"] == "wireguard" }
# Make sure the deployKey volumeMount is present in the sidecar container
vpnconfigVolumeMount = vpnContainer["volumeMounts"].find { |v| v["name"] == "vpnconfig"}
refute_nil(vpnconfigVolumeMount)
assert_equal("/etc/wireguard/wg0.conf", vpnconfigVolumeMount["mountPath"])
end
end
end
end