1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Gitlab variables pagination (#968)

* Workaround increasing per_page to max

* Update plugins/modules/source_control/gitlab/gitlab_group_variable.py

* Create 968-gitlab_variables-pagination-increase.yml

* Update changelogs/fragments/968-gitlab_variables-pagination-increase.yml

Co-authored-by: Felix Fontein <felix@fontein.de>

* Update changelogs/fragments/968-gitlab_variables-pagination-increase.yml

Co-authored-by: Felix Fontein <felix@fontein.de>

* Proper support of pagination

* Fix E303 too many blank lines

* Add test for pagination

* Fix last vars removal test

* Apply suggestions from code review

Check misalignement fixed

Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
S Code Man 2020-10-09 20:59:00 +08:00 committed by GitHub
parent 3af4be34b2
commit 98486c0ee2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 170 additions and 8 deletions

View file

@ -0,0 +1,4 @@
---
bugfixes:
- gitlab_project_variable - support for GitLab pagination limitation by iterating over GitLab variable pages (https://github.com/ansible-collections/community.general/pull/968).
- gitlab_group_variable - support for GitLab pagination limitation by iterating over GitLab variable pages (https://github.com/ansible-collections/community.general/pull/968).

View file

@ -158,7 +158,14 @@ class GitlabGroupVariables(object):
return self.repo.groups.get(group_name) return self.repo.groups.get(group_name)
def list_all_group_variables(self): def list_all_group_variables(self):
return self.group.variables.list() page_nb = 1
variables = []
vars_page = self.group.variables.list(page=page_nb)
while len(vars_page) > 0:
variables += vars_page
page_nb += 1
vars_page = self.group.variables.list(page=page_nb)
return variables
def create_variable(self, key, value, masked, protected, variable_type): def create_variable(self, key, value, masked, protected, variable_type):
if self._module.check_mode: if self._module.check_mode:

View file

@ -155,7 +155,14 @@ class GitlabProjectVariables(object):
return self.repo.projects.get(project_name) return self.repo.projects.get(project_name)
def list_all_project_variables(self): def list_all_project_variables(self):
return self.project.variables.list() page_nb = 1
variables = []
vars_page = self.project.variables.list(page=page_nb)
while len(vars_page) > 0:
variables += vars_page
page_nb += 1
vars_page = self.project.variables.list(page=page_nb)
return variables
def create_variable(self, key, value, masked, protected, variable_type): def create_variable(self, key, value, masked, protected, variable_type):
if self._module.check_mode: if self._module.check_mode:

View file

@ -495,6 +495,78 @@
- gitlab_group_variable_state.group_variable.updated|length == 0 - gitlab_group_variable_state.group_variable.updated|length == 0
- gitlab_group_variable_state.group_variable.removed[0] == "my_test_var" - gitlab_group_variable_state.group_variable.removed[0] == "my_test_var"
- name: set complete page and purge existing ones
gitlab_group_variable:
api_url: "{{ gitlab_host }}"
api_token: "{{ gitlab_login_token }}"
group: "{{ gitlab_group_name }}"
vars:
page1_var01: value
page1_var02: value
page1_var03: value
page1_var04: value
page1_var05: value
page1_var06: value
page1_var07: value
page1_var08: value
page1_var09: value
page1_var10: value
page1_var11: value
page1_var12: value
page1_var13: value
page1_var14: value
page1_var15: value
page1_var16: value
page1_var17: value
page1_var18: value
page1_var19: value
page1_var20: value
purge: True
register: gitlab_group_variable_state
- name: complete page added state must be changed
assert:
that:
- gitlab_group_variable_state is changed
- gitlab_group_variable_state.group_variable.added|length == 20
- gitlab_group_variable_state.group_variable.untouched|length == 0
- name: set complete page and keep existing ones
gitlab_group_variable:
api_url: "{{ gitlab_host }}"
api_token: "{{ gitlab_login_token }}"
group: "{{ gitlab_group_name }}"
vars:
page2_var01: value
page2_var02: value
page2_var03: value
page2_var04: value
page2_var05: value
page2_var06: value
page2_var07: value
page2_var08: value
page2_var09: value
page2_var10: value
page2_var11: value
page2_var12: value
page2_var13: value
page2_var14: value
page2_var15: value
page2_var16: value
page2_var17: value
page2_var18: value
page2_var19: value
page2_var20: value
purge: False
register: gitlab_group_variable_state
- name: existing page untouched state must be changed
assert:
that:
- gitlab_group_variable_state is changed
- gitlab_group_variable_state.group_variable.added|length == 20
- gitlab_group_variable_state.group_variable.untouched|length == 20
- name: check that no variables are left - name: check that no variables are left
gitlab_group_variable: gitlab_group_variable:
api_url: "{{ gitlab_host }}" api_url: "{{ gitlab_host }}"
@ -503,11 +575,11 @@
purge: True purge: True
register: gitlab_group_variable_state register: gitlab_group_variable_state
- name: check that no variables are untoucheded state must be changed - name: check that no variables are untouched state must be changed
assert: assert:
that: that:
- not gitlab_group_variable_state.changed - gitlab_group_variable_state.changed
- gitlab_group_variable_state.group_variable.added|length == 0 - gitlab_group_variable_state.group_variable.added|length == 0
- gitlab_group_variable_state.group_variable.untouched|length == 0 - gitlab_group_variable_state.group_variable.untouched|length == 0
- gitlab_group_variable_state.group_variable.removed|length == 0 - gitlab_group_variable_state.group_variable.removed|length == 40
- gitlab_group_variable_state.group_variable.updated|length == 0 - gitlab_group_variable_state.group_variable.updated|length == 0

View file

@ -494,6 +494,78 @@
- gitlab_project_variable_state.project_variable.updated|length == 0 - gitlab_project_variable_state.project_variable.updated|length == 0
- gitlab_project_variable_state.project_variable.removed[0] == "my_test_var" - gitlab_project_variable_state.project_variable.removed[0] == "my_test_var"
- name: set complete page and purge existing ones
gitlab_project_variable:
api_url: "{{ gitlab_host }}"
api_token: "{{ gitlab_login_token }}"
project: "{{ gitlab_project_name }}"
vars:
page1_var01: value
page1_var02: value
page1_var03: value
page1_var04: value
page1_var05: value
page1_var06: value
page1_var07: value
page1_var08: value
page1_var09: value
page1_var10: value
page1_var11: value
page1_var12: value
page1_var13: value
page1_var14: value
page1_var15: value
page1_var16: value
page1_var17: value
page1_var18: value
page1_var19: value
page1_var20: value
purge: True
register: gitlab_project_variable_state
- name: complete page added state must be changed
assert:
that:
- gitlab_project_variable_state is changed
- gitlab_project_variable_state.project_variable.added|length == 20
- gitlab_project_variable_state.project_variable.untouched|length == 0
- name: set complete page and keep existing ones
gitlab_project_variable:
api_url: "{{ gitlab_host }}"
api_token: "{{ gitlab_login_token }}"
project: "{{ gitlab_project_name }}"
vars:
page2_var01: value
page2_var02: value
page2_var03: value
page2_var04: value
page2_var05: value
page2_var06: value
page2_var07: value
page2_var08: value
page2_var09: value
page2_var10: value
page2_var11: value
page2_var12: value
page2_var13: value
page2_var14: value
page2_var15: value
page2_var16: value
page2_var17: value
page2_var18: value
page2_var19: value
page2_var20: value
purge: False
register: gitlab_project_variable_state
- name: existing page untouched state must be changed
assert:
that:
- gitlab_project_variable_state is changed
- gitlab_project_variable_state.project_variable.added|length == 20
- gitlab_project_variable_state.project_variable.untouched|length == 20
- name: check that no variables are left - name: check that no variables are left
gitlab_project_variable: gitlab_project_variable:
api_url: "{{ gitlab_host }}" api_url: "{{ gitlab_host }}"
@ -502,11 +574,11 @@
purge: True purge: True
register: gitlab_project_variable_state register: gitlab_project_variable_state
- name: check that no variables are untoucheded state must be changed - name: check that no variables are untouched state must be changed
assert: assert:
that: that:
- not gitlab_project_variable_state.changed - gitlab_project_variable_state.changed
- gitlab_project_variable_state.project_variable.added|length == 0 - gitlab_project_variable_state.project_variable.added|length == 0
- gitlab_project_variable_state.project_variable.untouched|length == 0 - gitlab_project_variable_state.project_variable.untouched|length == 0
- gitlab_project_variable_state.project_variable.removed|length == 0 - gitlab_project_variable_state.project_variable.removed|length == 40
- gitlab_project_variable_state.project_variable.updated|length == 0 - gitlab_project_variable_state.project_variable.updated|length == 0