質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Linux Mint

Linux Mintは、使いやすいLinuxシステムの提供を目的としたLinuxディストリビューションです。UbuntuとDebianをベースにしており、Ubuntuのリポジトリを共有しています。

Ansible

Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

1回答

3371閲覧

Ansible MoleculeのDockerドライバーでのテスト実施ができない

Yuta_for

総合スコア21

Linux Mint

Linux Mintは、使いやすいLinuxシステムの提供を目的としたLinuxディストリビューションです。UbuntuとDebianをベースにしており、Ubuntuのリポジトリを共有しています。

Ansible

Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2020/10/31 10:46

背景

AnsibleのRoleのテストを練習するために、Moleculeをインストールしてみたのですが、試しに作成したmolecule.ymlが上手くいかず、moleculeの理解が深められていない状態です。

環境情報

PC:Linux Mint 20 Ulyana
Ansible:2.9.13
Python:3.8.2
Docker:19.03.13
(pip docker:4.3.1)
molecule 3.1.5

  • ansible:2.9.13 python:3.8
  • delegated:3.1.5 from molecule
  • docker:0.2.4 from molecule_docker

やったこと

moleculeをインストール後、molecule init role first-molでテンプレートディレクトリを作成し、`molecule.yml'を以下のように変更しました。

yaml

1--- 2dependency: 3 name: galaxy 4driver: 5 name: docker 6platforms: 7 - name: instance1 8 image: docker.io/centos:7 9 pre_build_image: true 10 privileged: True 11 command: /sbin/init 12 13 - name: instance2 14 image: docker.io/centos:8 15 pre_build_image: true 16 privileged: True 17 command: /sbin/init 18 19provisioner: 20 name: ansible 21verifier: 22 name: ansible

その後、molecule convergeを実行して、テスト用環境が構築されるか確かめてみました。

$ molecule converge --> Test matrix └── default ├── dependency ├── create ├── prepare └── converge --> Scenario: 'default' --> Action: 'dependency' Skipping, missing the requirements file. Skipping, missing the requirements file. --> Scenario: 'default' --> Action: 'create' Skipping, instances already created. --> Scenario: 'default' --> Action: 'prepare' Skipping, prepare playbook not configured. --> Scenario: 'default' --> Action: 'converge' --> Sanity checks: 'docker' PLAY [Converge] **************************************************************** TASK [Gathering Facts] ********************************************************* fatal: [instance2]: UNREACHABLE! => {"changed": false, "msg": "Failed to create temporary directory.In some cases, you may have been able to authenticate and did not have permissions on the target directory. Consider changing the remote tmp path in ansible.cfg to a path rooted in \"/tmp\", for more error information use -vvv. Failed command was: ( umask 77 && mkdir -p \"` echo ~/.ansible/tmp `\"&& mkdir \"` echo ~/.ansible/tmp/ansible-tmp-1604140764.6588757-41870-218071143806516 `\" && echo ansible-tmp-1604140764.6588757-41870-218071143806516=\"` echo ~/.ansible/tmp/ansible-tmp-1604140764.6588757-41870-218071143806516 `\" ), exited with result 1", "unreachable": true} fatal: [instance1]: UNREACHABLE! => {"changed": false, "msg": "Failed to create temporary directory.In some cases, you may have been able to authenticate and did not have permissions on the target directory. Consider changing the remote tmp path in ansible.cfg to a path rooted in \"/tmp\", for more error information use -vvv. Failed command was: ( umask 77 && mkdir -p \"` echo ~/.ansible/tmp `\"&& mkdir \"` echo ~/.ansible/tmp/ansible-tmp-1604140764.6792333-41869-223215650844468 `\" && echo ansible-tmp-1604140764.6792333-41869-223215650844468=\"` echo ~/.ansible/tmp/ansible-tmp-1604140764.6792333-41869-223215650844468 `\" ), exited with result 1", "unreachable": true} PLAY RECAP ********************************************************************* instance1 : ok=0 changed=0 unreachable=1 failed=0 skipped=0 rescued=0 ignored=0 instance2 : ok=0 changed=0 unreachable=1 failed=0 skipped=0 rescued=0 ignored=0 ERROR:

molecule listを確認しますとconvergeがfalseにいることを確認しました。

$ molecule list Status(instance_name='instance1', driver_name='docker', provisioner_name='ansible', scenario_name='default', created='true', converged='false') Status(instance_name='instance2', driver_name='docker', provisioner_name='ansible', scenario_name='default', created='true', converged='false') ╷ ╷ ╷ ╷ ╷ Instance Name │ Driver Name │ Provisioner Name │ Scenario Name │ Created │ Converged ╶───────────────┼─────────────┼──────────────────┼───────────────┼─────────┼───────────╴ instance1 │ docker │ ansible │ default │ true │ false instance2 │ docker │ ansible │ default │ true │ false ╵ ╵ ╵ ╵ ╵

TASKGathering Factsの所で、tempディレクトリの作成に失敗していることがわかり、パーミッションエラーとも出ているのですが、何に対するパーミッションエラーなのか原因が判明しません。

エラー原因がわかる方いましたらご教授お願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

同じエラーが確認できました。
moleculeのシナリオディレクトリに create.yml destroy.yml が存在していないでしょうか?
もし、存在していたら削除してから molecule test を実行してみてください。

# molecule init role first-mol # cd first-mol/ # vi molecule/default/molecule.yml --- dependency: name: galaxy driver: name: docker platforms: - name: instance1 image: docker.io/centos:7 pre_build_image: true privileged: True command: /sbin/init - name: instance2 image: docker.io/centos:8 pre_build_image: true privileged: True command: /sbin/init provisioner: name: ansible verifier: name: ansible # rm -f molecule/default/{create.yml,destroy.yml} # ls molecule/default/ INSTALL.rst converge.yml molecule.yml verify.yml # molecule test

これで、エラーは発生せずに動作しました。

環境情報

# python --version Python 3.6.8 # ansible --version ansible 2.9.13 # molecule --version molecule 3.1.5 # pip show molecule-docker Version: 0.2.4

投稿2020/10/31 12:16

編集2020/10/31 12:19
sky-joker

総合スコア44

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Yuta_for

2020/10/31 16:07

ありがとうございます! molecule init role時にできていたcreate.ymlとdestory.ymlを削除したら無事にテストが通りました。 CentOS8でmolecule init roleしたときはこんなものは出てこなかったのですが、Ubuntu系だとあるのですかね? 不思議です。
sky-joker

2020/11/01 13:52

解決してよかったです :) moleculeは3.1.0(α版含む)からデフォルトドライバがdelegatedになったので、最新版だと自動的に `create.yml` と `destroy.yml` が作成されるようになりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問