Completed
Pull Request — master (#474)
by
unknown
03:25
created

GetJobStatus   A

Complexity

Total Complexity 10

Size/Duplication

Total Lines 38
Duplicated Lines 0 %
Metric Value
dl 0
loc 38
rs 10
wmc 10

1 Method

Rating   Name   Duplication   Size   Complexity  
F run() 0 37 10
1
# Licensed to the StackStorm, Inc ('StackStorm') under one or more
2
# contributor license agreements.  See the NOTICE file distributed with
3
# this work for additional information regarding copyright ownership.
4
# The ASF licenses this file to You under the Apache License, Version 2.0
5
# (the "License"); you may not use this file except in compliance with
6
# the License.  You may obtain a copy of the License at
7
#
8
#     http://www.apache.org/licenses/LICENSE-2.0
9
#
10
# Unless required by applicable law or agreed to in writing, software
11
# distributed under the License is distributed on an "AS IS" BASIS,
12
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
# See the License for the specific language governing permissions and
14
# limitations under the License.
15
16
from lib.icsp import ICSPBaseActions
17
import eventlet
18
19
20
class GetJobStatus(ICSPBaseActions):
21
    def run(self, job_id, monitor, connection_details):
22
        if connection_details:
23
            self.setConnection(connection_details)
24
        self.getSessionID()
25
26
        output = {}
27
        endpoint = "/rest/os-deployment-jobs"
28
        if monitor and not job_id:
29
            raise ValueError("Unable to proceed. Monitor \
30
                             feature requires a single Job ID")
31
32
        if job_id:
33
            endpoint = endpoint + "/%s" % job_id
34
35
        jobs = self.icspGET(endpoint)
36
        # Single Job ID doesn't have Members element
37
        if not job_id:
38
            for job in jobs['members']:
39
                jobid = job["uri"].split("/")[-1]
40
                output[jobid] = job['state']
41
        else:
42
            status = jobs['state']
43
            if monitor:
44
                jobid = jobs["uri"].split("/")[-1]
45
                while status == "STATUS_ACTIVE":
46
                    eventlet.sleep(120)
47
                    jobs = self.icspGET(endpoint)
48
                    status = jobs['state']
49
                if status == 'STATUS_SUCCESS':
50
                    output[jobid] = jobs['state']
51
                else:
52
                    raise Exception("%s: %s" % (jobid, status))
53
            else:
54
                jobid = jobs["uri"].split("/")[-1]
55
                output[jobid] = jobs['state']
56
57
        return {"jobs": output}
58