123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Gql::Mutations::User::AddFirstAdmin, :aggregate_failures, set_up: false, type: :request do
- context 'when adding the first admin user' do
- let(:query) do
- <<~QUERY
- mutation userAddFirstAdmin($input: UserSignupInput!) {
- userAddFirstAdmin(input: $input) {
- session {
- id
- afterAuth {
- type
- data
- }
- }
- errors {
- message
- field
- }
- }
- }
- QUERY
- end
- let(:variables) do
- {
- input: {
- email: 'bender@futurama.fiction',
- firstname: 'Bender',
- lastname: 'Rodríguez',
- password: 'IloveBender1337'
- }
- }
- end
- let(:headers) do
- {
- 'X-Browser-Fingerprint' => 'some-fingerprint',
- }
- end
- let(:graphql_response) do
- post '/graphql', params: { query: query, variables: variables }, headers: headers, as: :json
- json_response
- end
- before do
- allow(Calendar).to receive(:init_setup)
- allow(TextModule).to receive(:load)
- Setting.set('system_init_done', false)
- end
- context 'with an empty system' do
- it 'creates a new user' do
- expect(graphql_response['data']['userAddFirstAdmin']).to include({ 'session' => include({ 'id' => a_kind_of(String) }), 'errors' => nil })
- expect(User.find_by(email: 'bender@futurama.fiction')).to be_present
- expect(Calendar).to have_received(:init_setup)
- expect(TextModule).to have_received(:load)
- end
- end
- context 'without an email address' do
- let(:variables) do
- {
- input: {
- email: '',
- firstname: 'Bender',
- lastname: 'Rodríguez',
- password: 'IloveBender1337'
- }
- }
- end
- it 'fails with an error' do
- expect(graphql_response['errors'].first['message']).to eq("The required attribute 'email' is missing.")
- end
- end
- context 'with a weak password' do
- let(:variables) do
- {
- input: {
- email: 'bender@futurama.fiction',
- firstname: 'Bender',
- lastname: 'Rodríguez',
- password: '1234'
- }
- }
- end
- it 'fails with an error' do
- expect(graphql_response['data']['userAddFirstAdmin']['errors'].first['message']).to match(%r{Invalid password})
- end
- end
- context 'when system has already been configured' do
- before do
- Setting.set('system_init_done', true)
- create(:admin)
- end
- it 'fails with an error' do
- expect(graphql_response['data']['userAddFirstAdmin']['errors']).to eq(
- [{ 'message' => 'This system has already been configured and an administrator account exists.', 'field' => nil }]
- )
- end
- end
- end
- end
|