2020-05-24 23:13:21 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Gitlab::Kubernetes::NetworkPolicy do
|
2020-05-24 23:13:21 +05:30
|
|
|
let(:policy) do
|
|
|
|
described_class.new(
|
|
|
|
name: name,
|
|
|
|
namespace: namespace,
|
|
|
|
creation_timestamp: '2020-04-14T00:08:30Z',
|
2020-10-24 23:57:45 +05:30
|
|
|
selector: pod_selector,
|
2020-05-24 23:13:21 +05:30
|
|
|
policy_types: %w(Ingress Egress),
|
|
|
|
ingress: ingress,
|
|
|
|
egress: egress
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
let(:resource) do
|
|
|
|
::Kubeclient::Resource.new(
|
|
|
|
metadata: { name: name, namespace: namespace },
|
|
|
|
spec: { podSelector: pod_selector, policyTypes: %w(Ingress), ingress: ingress, egress: nil }
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
let(:name) { 'example-name' }
|
|
|
|
let(:namespace) { 'example-namespace' }
|
|
|
|
let(:pod_selector) { { matchLabels: { role: 'db' } } }
|
|
|
|
|
|
|
|
let(:ingress) do
|
|
|
|
[
|
|
|
|
{
|
|
|
|
from: [
|
|
|
|
{ namespaceSelector: { matchLabels: { project: 'myproject' } } }
|
|
|
|
]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:egress) do
|
|
|
|
[
|
|
|
|
{
|
|
|
|
ports: [{ port: 5978 }]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
include_examples 'network policy common specs' do
|
|
|
|
let(:selector) { pod_selector }
|
|
|
|
let(:policy) do
|
|
|
|
described_class.new(
|
|
|
|
name: name,
|
|
|
|
namespace: namespace,
|
|
|
|
selector: selector,
|
|
|
|
ingress: ingress,
|
|
|
|
labels: labels
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:spec) { { podSelector: selector, policyTypes: ["Ingress"], ingress: ingress, egress: nil } }
|
|
|
|
let(:metadata) { { name: name, namespace: namespace } }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#generate' do
|
|
|
|
subject { policy.generate }
|
|
|
|
|
|
|
|
it { is_expected.to eq(resource) }
|
|
|
|
end
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
describe '.from_yaml' do
|
|
|
|
let(:manifest) do
|
2020-06-23 00:09:42 +05:30
|
|
|
<<~POLICY
|
|
|
|
apiVersion: networking.k8s.io/v1
|
|
|
|
kind: NetworkPolicy
|
|
|
|
metadata:
|
|
|
|
name: example-name
|
|
|
|
namespace: example-namespace
|
|
|
|
spec:
|
|
|
|
podSelector:
|
|
|
|
matchLabels:
|
|
|
|
role: db
|
|
|
|
policyTypes:
|
|
|
|
- Ingress
|
|
|
|
ingress:
|
|
|
|
- from:
|
|
|
|
- namespaceSelector:
|
|
|
|
matchLabels:
|
|
|
|
project: myproject
|
2020-05-24 23:13:21 +05:30
|
|
|
POLICY
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { Gitlab::Kubernetes::NetworkPolicy.from_yaml(manifest)&.generate }
|
|
|
|
|
|
|
|
it { is_expected.to eq(resource) }
|
|
|
|
|
|
|
|
context 'with nil manifest' do
|
|
|
|
let(:manifest) { nil }
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with invalid manifest' do
|
|
|
|
let(:manifest) { "\tfoo: bar" }
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with manifest without metadata' do
|
|
|
|
let(:manifest) do
|
2020-06-23 00:09:42 +05:30
|
|
|
<<~POLICY
|
|
|
|
apiVersion: networking.k8s.io/v1
|
|
|
|
kind: NetworkPolicy
|
|
|
|
spec:
|
|
|
|
podSelector:
|
|
|
|
matchLabels:
|
|
|
|
role: db
|
|
|
|
policyTypes:
|
|
|
|
- Ingress
|
|
|
|
ingress:
|
|
|
|
- from:
|
|
|
|
- namespaceSelector:
|
|
|
|
matchLabels:
|
|
|
|
project: myproject
|
2020-05-24 23:13:21 +05:30
|
|
|
POLICY
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with manifest without spec' do
|
|
|
|
let(:manifest) do
|
2020-06-23 00:09:42 +05:30
|
|
|
<<~POLICY
|
|
|
|
apiVersion: networking.k8s.io/v1
|
|
|
|
kind: NetworkPolicy
|
|
|
|
metadata:
|
|
|
|
name: example-name
|
|
|
|
namespace: example-namespace
|
2020-05-24 23:13:21 +05:30
|
|
|
POLICY
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with disallowed class' do
|
|
|
|
let(:manifest) do
|
2020-06-23 00:09:42 +05:30
|
|
|
<<~POLICY
|
|
|
|
apiVersion: networking.k8s.io/v1
|
|
|
|
kind: NetworkPolicy
|
|
|
|
metadata:
|
|
|
|
name: example-name
|
|
|
|
namespace: example-namespace
|
|
|
|
creationTimestamp: 2020-04-14T00:08:30Z
|
|
|
|
spec:
|
|
|
|
podSelector:
|
|
|
|
matchLabels:
|
|
|
|
role: db
|
|
|
|
policyTypes:
|
|
|
|
- Ingress
|
|
|
|
ingress:
|
|
|
|
- from:
|
|
|
|
- namespaceSelector:
|
|
|
|
matchLabels:
|
|
|
|
project: myproject
|
2020-05-24 23:13:21 +05:30
|
|
|
POLICY
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.from_resource' do
|
|
|
|
let(:resource) do
|
|
|
|
::Kubeclient::Resource.new(
|
2020-06-23 00:09:42 +05:30
|
|
|
metadata: {
|
|
|
|
name: name, namespace: namespace, creationTimestamp: '2020-04-14T00:08:30Z',
|
|
|
|
labels: { app: 'foo' }, resourceVersion: '4990'
|
|
|
|
},
|
2020-05-24 23:13:21 +05:30
|
|
|
spec: { podSelector: pod_selector, policyTypes: %w(Ingress), ingress: ingress, egress: nil }
|
|
|
|
)
|
|
|
|
end
|
2020-10-24 23:57:45 +05:30
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
let(:generated_resource) do
|
|
|
|
::Kubeclient::Resource.new(
|
2020-06-23 00:09:42 +05:30
|
|
|
metadata: { name: name, namespace: namespace, labels: { app: 'foo' } },
|
2020-05-24 23:13:21 +05:30
|
|
|
spec: { podSelector: pod_selector, policyTypes: %w(Ingress), ingress: ingress, egress: nil }
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { Gitlab::Kubernetes::NetworkPolicy.from_resource(resource)&.generate }
|
|
|
|
|
|
|
|
it { is_expected.to eq(generated_resource) }
|
|
|
|
|
|
|
|
context 'with nil resource' do
|
|
|
|
let(:resource) { nil }
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with resource without metadata' do
|
|
|
|
let(:resource) do
|
|
|
|
::Kubeclient::Resource.new(
|
|
|
|
spec: { podSelector: pod_selector, policyTypes: %w(Ingress), ingress: ingress, egress: nil }
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with resource without spec' do
|
|
|
|
let(:resource) do
|
|
|
|
::Kubeclient::Resource.new(
|
|
|
|
metadata: { name: name, namespace: namespace, uid: '128cf288-7de4-11ea-aceb-42010a800089', resourceVersion: '4990' }
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|