| #!/usr/bin/python3 |
| # |
| # OSM devops/charms - Ansible charm inside OSM devops |
| # |
| # Copyright 2017-2018 Universidad Carlos III de Madrid |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| |
| import amulet |
| import requests |
| import unittest |
| |
| |
| class TestCharm(unittest.TestCase): |
| def setUp(self): |
| self.d = amulet.Deployment() |
| |
| self.d.add('ansible-charm') |
| self.d.expose('ansible-charm') |
| |
| self.d.setup(timeout=900) |
| self.d.sentry.wait() |
| |
| self.unit = self.d.sentry['ansible-charm'][0] |
| |
| def test_service(self): |
| # test we can access over http |
| page = requests.get('http://{}'.format(self.unit.info['public-address'])) |
| self.assertEqual(page.status_code, 200) |
| # Now you can use self.d.sentry[SERVICE][UNIT] to address each of the units and perform |
| # more in-depth steps. Each self.d.sentry[SERVICE][UNIT] has the following methods: |
| # - .info - An array of the information of that unit from Juju |
| # - .file(PATH) - Get the details of a file on that unit |
| # - .file_contents(PATH) - Get plain text output of PATH file from that unit |
| # - .directory(PATH) - Get details of directory |
| # - .directory_contents(PATH) - List files and folders in PATH on that unit |
| # - .relation(relation, service:rel) - Get relation data from return service |
| |
| |
| if __name__ == '__main__': |
| unittest.main() |