1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
# frozen_string_literal: true
require "spec_helper"
module SecureHeaders
describe XPermittedCrossDomainPolicies do
specify { expect(XPermittedCrossDomainPolicies.make_header).to eq([XPermittedCrossDomainPolicies::HEADER_NAME, "none"]) }
specify { expect(XPermittedCrossDomainPolicies.make_header("master-only")).to eq([XPermittedCrossDomainPolicies::HEADER_NAME, "master-only"]) }
context "valid configuration values" do
it "accepts 'all'" do
expect do
XPermittedCrossDomainPolicies.validate_config!("all")
end.not_to raise_error
end
it "accepts 'by-ftp-filename'" do
expect do
XPermittedCrossDomainPolicies.validate_config!("by-ftp-filename")
end.not_to raise_error
end
it "accepts 'by-content-type'" do
expect do
XPermittedCrossDomainPolicies.validate_config!("by-content-type")
end.not_to raise_error
end
it "accepts 'master-only'" do
expect do
XPermittedCrossDomainPolicies.validate_config!("master-only")
end.not_to raise_error
end
it "accepts nil" do
expect do
XPermittedCrossDomainPolicies.validate_config!(nil)
end.not_to raise_error
end
end
context "invlaid configuration values" do
it "doesn't accept invalid values" do
expect do
XPermittedCrossDomainPolicies.validate_config!("open")
end.to raise_error(XPCDPConfigError)
end
end
end
end
|