2022-08-05 21:31:34 +02:00
|
|
|
---
|
2020-09-25 09:01:17 +03:00
|
|
|
####################################################################
|
|
|
|
# WARNING: These are designed specifically for Ansible tests #
|
|
|
|
# and should not be used as examples of how to write Ansible roles #
|
|
|
|
####################################################################
|
|
|
|
|
2022-08-05 21:31:34 +02:00
|
|
|
# Copyright (c) Ansible Project
|
|
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: Install required libs
|
|
|
|
pip:
|
|
|
|
name: python-gitlab
|
|
|
|
state: present
|
|
|
|
|
|
|
|
- name: Clean up gitlab user
|
|
|
|
gitlab_user:
|
2021-02-09 10:29:13 +01:00
|
|
|
api_url: "{{ gitlab_host }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
name: ansible_test_user
|
|
|
|
username: ansible_test_user
|
|
|
|
password: Secr3tPassw00rd
|
|
|
|
email: root@localhost
|
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
state: absent
|
|
|
|
|
|
|
|
|
|
|
|
- name: Create gitlab user
|
|
|
|
gitlab_user:
|
2021-02-09 10:29:13 +01:00
|
|
|
api_url: "{{ gitlab_host }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
password: "{{ gitlab_user_pass }}"
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check user has been created correctly
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
|
|
|
|
- name: Create gitlab user again
|
|
|
|
gitlab_user:
|
2021-02-09 10:29:13 +01:00
|
|
|
api_url: "{{ gitlab_host }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
email: root@localhost
|
|
|
|
name: ansible_test_user
|
|
|
|
username: ansible_test_user
|
|
|
|
password: Secr3tPassw00rd
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
2020-03-09 09:11:07 +00:00
|
|
|
state: present
|
|
|
|
register: gitlab_user_state_again
|
|
|
|
|
|
|
|
- name: Check state is not changed
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state_again is not changed
|
2021-02-09 10:29:13 +01:00
|
|
|
- gitlab_user_state_again.user.is_admin == False
|
|
|
|
|
|
|
|
|
2021-05-14 12:30:59 +04:30
|
|
|
- name: Update User Test => Make User Admin
|
2021-02-09 10:29:13 +01:00
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
isadmin: true
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check if user is admin now
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
- gitlab_user_state.user.is_admin == True
|
|
|
|
|
|
|
|
- name: Update User Test => Make User Admin (Again)
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
isadmin: true
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check state is not changed
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is not changed
|
|
|
|
- gitlab_user_state.user.is_admin == True
|
|
|
|
|
|
|
|
- name: Update User Test => Remove Admin Rights
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
isadmin: false
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check if user is not admin anymore
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
- gitlab_user_state.user.is_admin == False
|
|
|
|
|
|
|
|
|
|
|
|
- name: Update User Test => Try Changing Mail without Confirmation Skipping
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: foo@bar.baz
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
2023-03-06 23:02:24 +01:00
|
|
|
confirm: true
|
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check that eMail is unchanged (Only works with confirmation skipping)
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
- gitlab_user_state.user.email == gitlab_user_email
|
|
|
|
|
|
|
|
- name: Update User Test => Change Mail with Confirmation Skip
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: foo@bar.baz
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
confirm: false
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check that mail has changed now
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
- gitlab_user_state.user.email == 'foo@bar.baz'
|
|
|
|
|
|
|
|
- name: Update User Test => Change Mail with Confirmation Skip (Again)
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: foo@bar.baz
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
confirm: false
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check state is not changed
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is not changed
|
|
|
|
- gitlab_user_state.user.email == 'foo@bar.baz'
|
|
|
|
|
|
|
|
- name: Update User Test => Revert to original Mail Address
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
confirm: false
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
api_token: "{{ gitlab_login_token }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check that reverting mail back to original has worked
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is changed
|
|
|
|
- gitlab_user_state.user.email == gitlab_user_email
|
|
|
|
|
|
|
|
|
|
|
|
- name: Update User Test => Change User Password
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
|
2021-05-14 12:30:59 +04:30
|
|
|
# note: the only way to check if a password really is what it is expected
|
|
|
|
# to be is to use it for login, so we use it here instead of the
|
2021-02-09 10:29:13 +01:00
|
|
|
# default token assuming that a user can always change its own password
|
|
|
|
api_username: "{{ gitlab_user }}"
|
|
|
|
api_password: "{{ gitlab_user_pass }}"
|
|
|
|
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
password: new-super-password
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check PW setting return state
|
|
|
|
assert:
|
|
|
|
that:
|
2021-05-14 12:30:59 +04:30
|
|
|
# note: there is no way to determine if a password has changed or
|
|
|
|
# not, so it can only be always yellow or always green, we
|
2021-02-09 10:29:13 +01:00
|
|
|
# decided for always green for now
|
|
|
|
- gitlab_user_state is not changed
|
|
|
|
|
|
|
|
- name: Update User Test => Reset User Password
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
|
|
|
|
api_username: "{{ gitlab_user }}"
|
|
|
|
api_password: new-super-password
|
|
|
|
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
password: "{{ gitlab_user_pass }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check PW setting return state (Again)
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is not changed
|
|
|
|
|
|
|
|
- name: Update User Test => Check that password was reset
|
|
|
|
gitlab_user:
|
|
|
|
api_url: "{{ gitlab_host }}"
|
2023-03-06 23:02:24 +01:00
|
|
|
validate_certs: false
|
2021-02-09 10:29:13 +01:00
|
|
|
|
|
|
|
api_username: "{{ gitlab_user }}"
|
|
|
|
api_password: "{{ gitlab_user_pass }}"
|
|
|
|
|
|
|
|
email: "{{ gitlab_user_email }}"
|
|
|
|
name: "{{ gitlab_user }}"
|
|
|
|
username: "{{ gitlab_user }}"
|
|
|
|
state: present
|
|
|
|
register: gitlab_user_state
|
|
|
|
|
|
|
|
- name: Check PW setting return state (Reset)
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- gitlab_user_state is not changed
|
2021-05-14 12:30:59 +04:30
|
|
|
|
|
|
|
- include_tasks: sshkey.yml
|