2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create test table called test_table
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
shell: psql postgres -U "{{ pg_user }}" -t -c "CREATE TABLE test_table (id int, story text);"
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - drop test tablespace called ssd if exists
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
shell: psql postgres -U "{{ pg_user }}" -t -c "DROP TABLESPACE IF EXISTS ssd;"
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - drop dir for test tablespace
|
|
|
|
become: true
|
|
|
|
file:
|
|
|
|
path: /mnt/ssd
|
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create dir for test tablespace
|
|
|
|
become: true
|
|
|
|
file:
|
|
|
|
path: /mnt/ssd
|
|
|
|
state: directory
|
|
|
|
owner: '{{ pg_user }}'
|
|
|
|
mode: '0755'
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create test tablespace called ssd
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
shell: psql postgres -U "{{ pg_user }}" -t -c "CREATE TABLESPACE ssd LOCATION '/mnt/ssd';"
|
|
|
|
ignore_errors: true
|
|
|
|
register: tablespace
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create test schema
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
shell: psql postgres -U "{{ pg_user }}" -t -c "CREATE SCHEMA foo;"
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create table in non-default schema
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
shell: psql postgres -U "{{ pg_user }}" -t -c "CREATE TABLE foo.foo_table (id int, story text);"
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create btree index in check_mode
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: id, story
|
2020-06-30 17:11:43 +03:00
|
|
|
idxname: Test0_idx
|
2020-03-09 09:11:07 +00:00
|
|
|
check_mode: true
|
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == ''
|
2020-06-30 17:11:43 +03:00
|
|
|
- result.name == 'Test0_idx'
|
2020-03-09 09:11:07 +00:00
|
|
|
- result.state == 'absent'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == ''
|
|
|
|
- result.query == ''
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - check nothing changed after the previous step
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_query:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
2020-06-30 17:11:43 +03:00
|
|
|
query: SELECT 1 FROM pg_indexes WHERE indexname = 'Test0_idx'
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.rowcount == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create btree index concurrently
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: id, story
|
2020-06-30 17:11:43 +03:00
|
|
|
idxname: Test0_idx
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: no
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == 'test_table'
|
2020-06-30 17:11:43 +03:00
|
|
|
- result.name == 'Test0_idx'
|
2020-03-09 09:11:07 +00:00
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == 'public'
|
2020-06-30 17:11:43 +03:00
|
|
|
- result.query == 'CREATE INDEX CONCURRENTLY "Test0_idx" ON "public"."test_table" USING BTREE (id, story)'
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - check the index exists after the previous step
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_query:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
2020-06-30 17:11:43 +03:00
|
|
|
query: SELECT 1 FROM pg_indexes WHERE indexname = 'Test0_idx'
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.rowcount == 1
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - try to create existing index again
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: id, story
|
2020-06-30 17:11:43 +03:00
|
|
|
idxname: Test0_idx
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is not changed
|
|
|
|
- result.tblname == 'test_table'
|
2020-06-30 17:11:43 +03:00
|
|
|
- result.name == 'Test0_idx'
|
2020-03-09 09:11:07 +00:00
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == 'public'
|
|
|
|
- result.query == ''
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create btree index - non-default schema, tablespace, storage parameter
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
schema: foo
|
|
|
|
table: foo_table
|
|
|
|
columns:
|
|
|
|
- id
|
|
|
|
- story
|
|
|
|
idxname: foo_test_idx
|
|
|
|
tablespace: ssd
|
|
|
|
storage_params: fillfactor=90
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: no
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == 'foo_table'
|
|
|
|
- result.name == 'foo_test_idx'
|
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == 'ssd'
|
|
|
|
- result.storage_params == [ "fillfactor=90" ]
|
|
|
|
- result.schema == 'foo'
|
2020-05-05 16:33:06 +03:00
|
|
|
- result.query == 'CREATE INDEX CONCURRENTLY "foo_test_idx" ON "foo"."foo_table" USING BTREE (id,story) WITH (fillfactor=90) TABLESPACE "ssd"'
|
2020-03-09 09:11:07 +00:00
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create brin index not concurrently
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
schema: public
|
|
|
|
table: test_table
|
|
|
|
state: present
|
|
|
|
type: brin
|
|
|
|
columns: id
|
|
|
|
idxname: test_brin_idx
|
|
|
|
concurrent: false
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: no
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == 'test_table'
|
|
|
|
- result.name == 'test_brin_idx'
|
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == 'public'
|
2020-05-05 16:33:06 +03:00
|
|
|
- result.query == 'CREATE INDEX "test_brin_idx" ON "public"."test_table" USING brin (id)'
|
2020-03-09 09:11:07 +00:00
|
|
|
when: postgres_version_resp.stdout is version('9.5', '>=')
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create index with condition
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: id
|
|
|
|
idxname: test1_idx
|
|
|
|
cond: id > 1 AND id != 10
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: no
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == 'test_table'
|
|
|
|
- result.name == 'test1_idx'
|
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == 'public'
|
2020-05-05 16:33:06 +03:00
|
|
|
- result.query == 'CREATE INDEX CONCURRENTLY "test1_idx" ON "public"."test_table" USING BTREE (id) WHERE id > 1 AND id != 10'
|
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - create unique index
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: story
|
|
|
|
idxname: test_unique0_idx
|
|
|
|
unique: true
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: no
|
2020-03-09 09:11:07 +00:00
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.tblname == 'test_table'
|
|
|
|
- result.name == 'test_unique0_idx'
|
|
|
|
- result.state == 'present'
|
|
|
|
- result.valid != ''
|
|
|
|
- result.tblspace == ''
|
|
|
|
- result.storage_params == []
|
|
|
|
- result.schema == 'public'
|
2020-05-05 16:33:06 +03:00
|
|
|
- result.query == 'CREATE UNIQUE INDEX CONCURRENTLY "test_unique0_idx" ON "public"."test_table" USING BTREE (story)'
|
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - avoid unique index with type different of btree
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
table: test_table
|
|
|
|
columns: story
|
|
|
|
idxname: test_unique0_idx
|
|
|
|
unique: true
|
|
|
|
concurrent: false
|
|
|
|
type: brin
|
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is not changed
|
|
|
|
- result.msg == 'Only btree currently supports unique indexes'
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - drop index from specific schema cascade in check_mode
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
schema: foo
|
|
|
|
name: foo_test_idx
|
|
|
|
cascade: true
|
|
|
|
state: absent
|
|
|
|
concurrent: false
|
2020-05-05 16:33:06 +03:00
|
|
|
trust_input: yes
|
2020-03-09 09:11:07 +00:00
|
|
|
check_mode: true
|
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.name == 'foo_test_idx'
|
|
|
|
- result.state == 'present'
|
|
|
|
- result.schema == 'foo'
|
|
|
|
- result.query == ''
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - check the index exists after the previous step
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_query:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
query: SELECT 1 FROM pg_indexes WHERE indexname = 'foo_test_idx' AND schemaname = 'foo'
|
|
|
|
register: result
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.rowcount == 1
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - drop index from specific schema cascade
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
schema: foo
|
|
|
|
name: foo_test_idx
|
|
|
|
cascade: true
|
|
|
|
state: absent
|
|
|
|
concurrent: false
|
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is changed
|
|
|
|
- result.name == 'foo_test_idx'
|
|
|
|
- result.state == 'absent'
|
|
|
|
- result.schema == 'foo'
|
2020-05-05 16:33:06 +03:00
|
|
|
- result.query == 'DROP INDEX "foo"."foo_test_idx" CASCADE'
|
2020-03-09 09:11:07 +00:00
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - check the index doesn't exist after the previous step
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_query:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
query: SELECT 1 FROM pg_indexes WHERE indexname = 'foo_test_idx' and schemaname = 'foo'
|
|
|
|
register: result
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result.rowcount == 0
|
|
|
|
when: tablespace.rc == 0
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- name: postgresql_idx - try to drop not existing index
|
|
|
|
become_user: '{{ pg_user }}'
|
|
|
|
become: true
|
|
|
|
postgresql_idx:
|
|
|
|
db: postgres
|
|
|
|
login_user: '{{ pg_user }}'
|
|
|
|
schema: foo
|
|
|
|
name: foo_test_idx
|
|
|
|
state: absent
|
|
|
|
register: result
|
|
|
|
ignore_errors: true
|
2020-05-05 16:33:06 +03:00
|
|
|
|
2020-03-09 09:11:07 +00:00
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- result is not changed
|
|
|
|
- result.query == ''
|