initial gitlab tests
This commit is contained in:
parent
e2d4d81745
commit
a83b2cd5f4
|
|
@ -0,0 +1,105 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe 'passbolt_api service' do
|
||||||
|
|
||||||
|
before(:all) do
|
||||||
|
@image = Docker::Image.build_from_dir(ROOT_DOCKERFILES)
|
||||||
|
@container = Docker::Container.create(
|
||||||
|
'Env' => [
|
||||||
|
"DATASOURCES_DEFAULT_HOST=db",
|
||||||
|
'DATASOURCES_DEFAULT_PASSWORD=±!@#$%^&*()_+=-}{|:;<>?',
|
||||||
|
'DATASOURCES_DEFAULT_USERNAME=passbolt',
|
||||||
|
'DATASOURCES_DEFAULT_DATABASE=passbolt',
|
||||||
|
'PASSBOLT_SSL_FORCE=true'
|
||||||
|
],
|
||||||
|
'Image' => @image.id)
|
||||||
|
@container.start
|
||||||
|
@container.logs(stdout: true)
|
||||||
|
|
||||||
|
set :docker_container, @container.id
|
||||||
|
sleep 17
|
||||||
|
end
|
||||||
|
|
||||||
|
after(:all) do
|
||||||
|
@container.kill
|
||||||
|
end
|
||||||
|
|
||||||
|
let(:passbolt_host) { @container.json['NetworkSettings']['IPAddress'] }
|
||||||
|
let(:uri) { "/healthcheck/status.json" }
|
||||||
|
let(:curl) { "curl -sk -o /dev/null -w '%{http_code}' -H 'Host: passbolt.local' https://#{passbolt_host}/#{uri}" }
|
||||||
|
|
||||||
|
describe 'php service' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('php-fpm')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'has its port open' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('9000/tcp')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'email cron' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('cron')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'web service' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('nginx')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is listening on port 80' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('80/tcp')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is listening on port 443' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('443/tcp')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt status' do
|
||||||
|
it 'returns 200' do
|
||||||
|
expect(command(curl).stdout).to eq '200'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt serverkey unaccessible' do
|
||||||
|
let(:uri) { '/config/gpg/serverkey.asc' }
|
||||||
|
it "returns 404" do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt serverkey private unaccessible' do
|
||||||
|
let(:uri) { '/config/gpg/serverkey_private.asc' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt conf unaccessible' do
|
||||||
|
let(:uri) { '/config/app.php' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'passbolt tmp folder is unaccessible' do
|
||||||
|
let(:uri) { '/tmp/cache/database/empty' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'hide information' do
|
||||||
|
let(:curl) { "curl -Isk -H 'Host: passbolt.local' https://#{passbolt_host}/" }
|
||||||
|
it 'hides php version' do
|
||||||
|
expect(command("#{curl} | grep 'X-Powered-By: PHP'").stdout).to be_empty
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'hides nginx version' do
|
||||||
|
expect(command("#{curl} | grep 'Server:'").stdout.strip).to match(/^Server:\s+nginx$/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
@ -0,0 +1,104 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe 'passbolt_api service' do
|
||||||
|
|
||||||
|
before(:all) do
|
||||||
|
@image = Docker::Image.build_from_dir(ROOT_DOCKERFILES)
|
||||||
|
|
||||||
|
@container = Docker::Container.create(
|
||||||
|
'Env' => [
|
||||||
|
"DATASOURCES_DEFAULT_HOST=db",
|
||||||
|
],
|
||||||
|
'Binds' => [ "#{FIXTURES_PATH + '/passbolt.php'}:/var/www/passbolt/config/passbolt.php" ],
|
||||||
|
'Image' => @image.id)
|
||||||
|
|
||||||
|
@container.start
|
||||||
|
@container.logs(stdout: true)
|
||||||
|
|
||||||
|
set :docker_container, @container.id
|
||||||
|
sleep 17
|
||||||
|
end
|
||||||
|
|
||||||
|
after(:all) do
|
||||||
|
@container.kill
|
||||||
|
end
|
||||||
|
|
||||||
|
let(:passbolt_host) { @container.json['NetworkSettings']['IPAddress'] }
|
||||||
|
let(:uri) { "/healthcheck/status.json" }
|
||||||
|
let(:curl) { "curl -sk -o /dev/null -w '%{http_code}' -H 'Host: passbolt.local' https://#{passbolt_host}/#{uri}" }
|
||||||
|
|
||||||
|
describe 'php service' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('php-fpm')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'has its port open' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('9000/tcp')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'email cron' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('cron')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'web service' do
|
||||||
|
it 'is running supervised' do
|
||||||
|
expect(service('nginx')).to be_running.under('supervisor')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is listening on port 80' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('80/tcp')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is listening on port 443' do
|
||||||
|
expect(@container.json['Config']['ExposedPorts']).to have_key('443/tcp')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt status' do
|
||||||
|
it 'returns 200' do
|
||||||
|
expect(command(curl).stdout).to eq '200'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt serverkey unaccessible' do
|
||||||
|
let(:uri) { '/config/gpg/serverkey.asc' }
|
||||||
|
it "returns 404" do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt serverkey private unaccessible' do
|
||||||
|
let(:uri) { '/config/gpg/serverkey_private.asc' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'passbolt conf unaccessible' do
|
||||||
|
let(:uri) { '/config/app.php' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'passbolt tmp folder is unaccessible' do
|
||||||
|
let(:uri) { '/tmp/cache/database/empty' }
|
||||||
|
it 'returns 404' do
|
||||||
|
expect(command(curl).stdout).to eq '404'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'hide information' do
|
||||||
|
let(:curl) { "curl -Isk -H 'Host: passbolt.local' https://#{passbolt_host}/" }
|
||||||
|
it 'hides php version' do
|
||||||
|
expect(command("#{curl} | grep 'X-Powered-By: PHP'").stdout).to be_empty
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'hides nginx version' do
|
||||||
|
expect(command("#{curl} | grep 'Server:'").stdout.strip).to match(/^Server:\s+nginx$/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
Loading…
Reference in New Issue