Sha256: 271ee82060c178da257824b71d284f2f2a735206031268d4c877cea7db442c6c

Contents?: true

Size: 1.72 KB

Versions: 2

Compression:

Stored size: 1.72 KB

Contents

require File.expand_path('../spec_helper.rb', __FILE__)

describe Rack::Protection::XSSHeader do
  it_behaves_like "any rack application"

  it 'should set the X-XSS-Protection' do
    get('/', {}, 'wants' => 'text/html;charset=utf-8').headers["X-XSS-Protection"].should == "1; mode=block"
  end

  it 'should set the X-XSS-Protection for XHTML' do
    get('/', {}, 'wants' => 'application/xhtml+xml').headers["X-XSS-Protection"].should == "1; mode=block"
  end

  it 'should not set the X-XSS-Protection for other content types' do
    get('/', {}, 'wants' => 'application/foo').headers["X-XSS-Protection"].should be_nil
  end

  it 'should allow changing the protection mode' do
    # I have no clue what other modes are available
    mock_app do
      use Rack::Protection::XSSHeader, :xss_mode => :foo
      run DummyApp
    end

    get('/', {}, 'wants' => 'application/xhtml').headers["X-XSS-Protection"].should == "1; mode=foo"
  end

  it 'should not override the header if already set' do
    mock_app with_headers("X-XSS-Protection" => "0")
    get('/', {}, 'wants' => 'text/html').headers["X-XSS-Protection"].should == "0"
  end

  it 'should set the X-Content-Type-Options' do
    get('/', {}, 'wants' => 'text/html').header["X-Content-Type-Options"].should == "nosniff"
  end

  it 'should allow changing the nosniff-mode off' do
    mock_app do
      use Rack::Protection::XSSHeader, :nosniff => false
      run DummyApp
    end

    get('/').headers["X-Content-Type-Options"].should be_nil
  end

  it 'should not override the header if already set X-Content-Type-Options' do
    mock_app with_headers("X-Content-Type-Options" => "sniff")
    get('/', {}, 'wants' => 'text/html').headers["X-Content-Type-Options"].should == "sniff"
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
rack-protection-1.3.2 spec/xss_header_spec.rb
rack-protection-1.3.1 spec/xss_header_spec.rb