blob: 5e84c136576d38e22aa253e134e0b10abc274bcd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
<!--
Copyright 2017,2019 Lars Wirzenius
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
-->
# Scenario step implementations for remote Ick
## Authentication setup
IMPLEMENTS GIVEN an access token for (\S+) with scopes (.+)
user = get_next_match()
scopes = get_next_match().split()
create_api_client(user, scopes)
token = get_api_token(user, scopes)
store_token(user, token)
## Controller configuration
IMPLEMENTS GIVEN controller config uses (\S+) at the state directory
V['statedir'] = get_next_match()
## Start and stop the controller
IMPLEMENTS GIVEN a running ick controller
V['url'] = os.environ['CONTROLLER']
IMPLEMENTS WHEN user stops ick controller
pass
IMPLEMENTS FINALLY stop ick controller
for client_id in get_client_ids():
delete_api_client(client_id)
## Controller state inspection
IMPLEMENTS THEN controller state directory contains project (\S+)
pass
IMPLEMENTS THEN controller state directory contains worker (\S+)
pass
|