diff --git a/.drone.jsonnet b/.drone.jsonnet index 810eaf7..e4f28eb 100644 --- a/.drone.jsonnet +++ b/.drone.jsonnet @@ -1,141 +1,155 @@ local PipelineLinting = { - kind: "pipeline", - name: "linting", - platform: { - os: "linux", - arch: "amd64", - }, - steps: [ - { - name: "ansible-later", - image: "xoxys/ansible-later:latest", - commands: [ - "ansible-later", - ], - }, - ], - trigger: { - ref: ["refs/heads/master", "refs/tags/**", "refs/pull/**"], + kind: 'pipeline', + name: 'linting', + platform: { + os: 'linux', + arch: 'amd64', + }, + steps: [ + { + name: 'ansible-later', + image: 'xoxys/ansible-later:latest', + commands: [ + 'ansible-later', + ], }, + ], + trigger: { + ref: ['refs/heads/master', 'refs/tags/**', 'refs/pull/**'], + }, }; -local PipelineDeployment = { - kind: "pipeline", - name: "deployment", - platform: { - os: "linux", - arch: "amd64", - }, - concurrency: { - limit: 1 - }, - workspace: { - base: "/drone/src", - path: "xoxys.jellyfin" - }, - steps: [ - { - name: "ansible-molecule", - image: "xoxys/molecule:latest", - environment: { - DO_API_KEY: { "from_secret": "do_api_key" }, - USER: "root", - MOLECULE_CUSTOM_MODULES_REPO: "https://gitea.rknet.org/ansible/custom_modules", - MOLECULE_CUSTOM_FILTERS_REPO: "https://gitea.rknet.org/ansible/custom_filters", - }, - commands: [ - "molecule test -s default", - ], - }, - ], - depends_on: [ - "linting", - ], - trigger: { - ref: ["refs/heads/master", "refs/tags/**"], +local PipelineDeployment(scenario='centos7') = { + kind: 'pipeline', + name: 'testing-' + scenario, + platform: { + os: 'linux', + arch: 'amd64', + }, + concurrency: { + limit: 1, + }, + workspace: { + base: '/drone/src', + path: 'xoxys.jellyfin', + }, + steps: [ + { + name: 'ansible-molecule', + image: 'xoxys/molecule:latest', + environment: { + DO_API_KEY: { from_secret: 'do_api_key' }, + USER: 'root', + MOLECULE_CUSTOM_MODULES_REPO: 'https://gitea.rknet.org/ansible/custom_modules', + MOLECULE_CUSTOM_FILTERS_REPO: 'https://gitea.rknet.org/ansible/custom_filters', + }, + commands: [ + 'molecule test -s' + scenario, + ], }, + ], + depends_on: [ + 'linting', + ], + trigger: { + ref: ['refs/heads/master', 'refs/tags/**'], + }, }; local PipelineDocumentation = { - kind: "pipeline", - name: "documentation", - platform: { - os: "linux", - arch: "amd64", + kind: 'pipeline', + name: 'documentation', + platform: { + os: 'linux', + arch: 'amd64', + }, + steps: [ + { + name: 'generate', + image: 'xoxys/ansible-doctor:latest', + environment: { + ANSIBLE_DOCTOR_LOG_LEVEL: 'INFO', + ANSIBLE_DOCTOR_FORCE_OVERWRITE: true, + ANSIBLE_DOCTOR_EXCLUDE_FILES: 'molecule/', + ANSIBLE_DOCTOR_TEMPLATE: 'hugo-book', + ANSIBLE_DOCTOR_ROLE_NAME: '${DRONE_REPO_NAME#*.}', + ANSIBLE_DOCTOR_OUTPUT_DIR: '_docs/', + }, }, - steps: [ - { - name: "ansible-doctor", - image: "xoxys/ansible-doctor:latest", - environment: { - ANSIBLE_DOCTOR_LOG_LEVEL: "INFO", - ANSIBLE_DOCTOR_FORCE_OVERWRITE: true, - ANSIBLE_DOCTOR_EXCLUDE_FILES: "molecule/", - ANSIBLE_DOCTOR_CUSTOM_HEADER: "HEADER.md", - }, - }, - { - name: "push-to-repo", - image: "plugins/git-action:latest", - settings: { - actions: ["commit", "push"], - author_email: "shipper@rknet.org", - author_name: "DroneShipper", - branch: "master", - message: "[SKIP CI] update readme", - remote: "https://gitea.rknet.org/ansible/xoxys.jellyfin", - netrc_machine: "gitea.rknet.org", - netrc_username: {"from_secret": "gitea_username"}, - netrc_password: {"from_secret": "gitea_token"}, - }, - when: { - ref: ["refs/heads/master"], - }, - }, - ], - depends_on: [ - "deployment", - ], - trigger: { - ref: ["refs/heads/master", "refs/tags/**", "refs/pull/**"], + { + name: 'publish', + image: 'plugins/gh-pages:latest', + settings: { + remote_url: 'https://gitea.rknet.org/ansible/xoxys.jellyfin', + netrc_machine: 'gitea.rknet.org', + username: { from_secret: 'gitea_username' }, + password: { from_secret: 'gitea_token' }, + pages_directory: '_docs/', + target_branch: 'docs', + }, + when: { + ref: ['refs/heads/master'], + }, }, + { + name: 'trigger', + image: 'plugins/downstream', + settings: { + server: 'https://drone.rknet.org', + token: { from_secret: 'drone_token' }, + fork: true, + repositories: [ + 'ansible/ansible-galaxy', + ], + }, + when: { + ref: ['refs/heads/master'], + }, + }, + ], + trigger: { + ref: ['refs/heads/master', 'refs/tags/**', 'refs/pull/**'], + }, + depends_on: [ + 'testing-centos7', + ], }; -local PipelineNotification= { - kind: "pipeline", - name: "notification", - platform: { - os: "linux", - arch: "amd64", - }, - clone: { - disable: true, - }, - steps: [ - { - name: "matrix", - image: "plugins/matrix", - settings: { - homeserver: { "from_secret": "matrix_homeserver" }, - roomid: { "from_secret": "matrix_roomid" }, - template: "Status: **{{ build.status }}**
Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}
Message: {{ build.message }}", - username: { "from_secret": "matrix_username" }, - password: { "from_secret": "matrix_password" }, - }, - }, - ], - depends_on: [ - "documentation", - ], - trigger: { - status: [ "success", "failure" ], - ref: ["refs/heads/master", "refs/tags/**"], +local PipelineNotification = { + kind: 'pipeline', + name: 'notification', + platform: { + os: 'linux', + arch: 'amd64', + }, + clone: { + disable: true, + }, + steps: [ + { + name: 'matrix', + image: 'plugins/matrix', + settings: { + homeserver: { from_secret: 'matrix_homeserver' }, + roomid: { from_secret: 'matrix_roomid' }, + template: 'Status: **{{ build.status }}**
Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}
Message: {{ build.message }}', + username: { from_secret: 'matrix_username' }, + password: { from_secret: 'matrix_password' }, + }, }, + ], + depends_on: [ + 'documentation', + ], + trigger: { + status: ['success', 'failure'], + ref: ['refs/heads/master', 'refs/tags/**'], + }, }; [ - PipelineLinting, - PipelineDeployment, - PipelineDocumentation, - PipelineNotification, + PipelineLinting, + PipelineDeployment(scenario='centos7'), + PipelineDocumentation, + PipelineNotification, ] diff --git a/.drone.yml b/.drone.yml index be0a288..98294b6 100644 --- a/.drone.yml +++ b/.drone.yml @@ -20,7 +20,7 @@ trigger: --- kind: pipeline -name: deployment +name: testing-centos7 platform: os: linux @@ -37,7 +37,7 @@ steps: - name: ansible-molecule image: xoxys/molecule:latest commands: - - molecule test -s default + - molecule test -scentos7 environment: DO_API_KEY: from_secret: do_api_key @@ -62,30 +62,40 @@ platform: arch: amd64 steps: -- name: ansible-doctor +- name: generate image: xoxys/ansible-doctor:latest environment: - ANSIBLE_DOCTOR_CUSTOM_HEADER: HEADER.md ANSIBLE_DOCTOR_EXCLUDE_FILES: molecule/ ANSIBLE_DOCTOR_FORCE_OVERWRITE: true ANSIBLE_DOCTOR_LOG_LEVEL: INFO + ANSIBLE_DOCTOR_OUTPUT_DIR: _docs/ + ANSIBLE_DOCTOR_ROLE_NAME: ${DRONE_REPO_NAME#*.} + ANSIBLE_DOCTOR_TEMPLATE: hugo-book -- name: push-to-repo - image: plugins/git-action:latest +- name: publish + image: plugins/gh-pages:latest settings: - actions: - - commit - - push - author_email: shipper@rknet.org - author_name: DroneShipper - branch: master - message: "[SKIP CI] update readme" netrc_machine: gitea.rknet.org - netrc_password: + pages_directory: _docs/ + password: from_secret: gitea_token - netrc_username: + remote_url: https://gitea.rknet.org/ansible/xoxys.jellyfin + target_branch: docs + username: from_secret: gitea_username - remote: https://gitea.rknet.org/ansible/xoxys.jellyfin + when: + ref: + - refs/heads/master + +- name: trigger + image: plugins/downstream + settings: + fork: true + repositories: + - ansible/ansible-galaxy + server: https://drone.rknet.org + token: + from_secret: drone_token when: ref: - refs/heads/master @@ -97,7 +107,7 @@ trigger: - refs/pull/** depends_on: -- deployment +- testing-centos7 --- kind: pipeline @@ -137,6 +147,6 @@ depends_on: --- kind: signature -hmac: 2bc870045380fae5a662d21dddca1a1709efb596f8b6ff5379574b5ddf06f2c3 +hmac: 3480654a168a1e4f1dad17426e3b5a5e90314285ca8b1b14c33dd3421b42526f ... diff --git a/HEADER.md b/HEADER.md deleted file mode 100644 index bc255b1..0000000 --- a/HEADER.md +++ /dev/null @@ -1,4 +0,0 @@ -# xoxys.jellyfin - -[![Build Status](https://drone.rknet.org/api/badges/ansible/xoxys.jellyfin/status.svg)](https://drone.rknet.org/ansible/xoxys.jellyfin) - diff --git a/molecule/default/create.yml b/molecule/centos7/create.yml similarity index 100% rename from molecule/default/create.yml rename to molecule/centos7/create.yml diff --git a/molecule/default/destroy.yml b/molecule/centos7/destroy.yml similarity index 100% rename from molecule/default/destroy.yml rename to molecule/centos7/destroy.yml diff --git a/molecule/default/molecule.yml b/molecule/centos7/molecule.yml similarity index 100% rename from molecule/default/molecule.yml rename to molecule/centos7/molecule.yml diff --git a/molecule/default/playbook.yml b/molecule/centos7/playbook.yml similarity index 100% rename from molecule/default/playbook.yml rename to molecule/centos7/playbook.yml diff --git a/molecule/default/prepare.yml b/molecule/centos7/prepare.yml similarity index 100% rename from molecule/default/prepare.yml rename to molecule/centos7/prepare.yml diff --git a/molecule/default/tests/test_default.py b/molecule/centos7/tests/test_default.py similarity index 100% rename from molecule/default/tests/test_default.py rename to molecule/centos7/tests/test_default.py diff --git a/molecule/default b/molecule/default new file mode 120000 index 0000000..2fdf3e8 --- /dev/null +++ b/molecule/default @@ -0,0 +1 @@ +centos7 \ No newline at end of file