[UI] Support UI partial control
[validation.git] / ui / src / main / java / org / akraino / validation / ui / service / JenkinsJobNotificationService.java
1 /*
2  * Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License"); you may
5  * not use this file except in compliance with the License. You may obtain
6  * 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
13  * implied. See the License for the specific language governing
14  * permissions and limitations under the License.
15  */
16 package org.akraino.validation.ui.service;
17
18 import java.util.ArrayList;
19 import java.util.List;
20
21 import org.akraino.validation.ui.client.nexus.resources.ValidationNexusTestResult;
22 import org.akraino.validation.ui.dao.ValidationTestResultDAO;
23 import org.akraino.validation.ui.data.JnksJobNotify;
24 import org.akraino.validation.ui.data.SubmissionStatus;
25 import org.akraino.validation.ui.entity.LabSilo;
26 import org.akraino.validation.ui.entity.Submission;
27 import org.akraino.validation.ui.entity.ValidationDbTestResult;
28 import org.akraino.validation.ui.service.utils.SubmissionHelper;
29 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
30 import org.springframework.beans.factory.annotation.Autowired;
31 import org.springframework.stereotype.Service;
32 import org.springframework.transaction.annotation.Transactional;
33
34 @Service
35 @Transactional
36 public class JenkinsJobNotificationService {
37
38     private static final EELFLoggerDelegate LOGGER = EELFLoggerDelegate.getLogger(JenkinsJobNotificationService.class);
39
40     @Autowired
41     private SubmissionHelper submissionHelper;
42
43     @Autowired
44     private DbSubmissionAdapter submissionService;
45
46     @Autowired
47     private SiloService siloService;
48
49     @Autowired
50     private DbResultAdapter dbAdapter;
51
52     @Autowired
53     private IntegratedResultService iService;
54
55     @Autowired
56     private ValidationTestResultDAO vTestResultDAO;
57
58     public void handle(JnksJobNotify jnksJobNotify) throws Exception {
59         String jenkinsJobName = System.getenv("JENKINS_JOB_NAME");
60         if (!jenkinsJobName.equals(jnksJobNotify.getName())) {
61             return;
62         }
63         Submission submission = submissionService.getSubmission(Integer.toString(jnksJobNotify.getSubmissionId()));
64         if (submission == null) {
65             LOGGER.debug(EELFLoggerDelegate.debugLogger, "No related submission was found");
66             return;
67         }
68         String siloText = null;
69         for (LabSilo silo : siloService.getSilos()) {
70             if (silo.getLab().getLab().equals(submission.getTimeslot().getLab().getLab())) {
71                 siloText = silo.getSilo();
72             }
73         }
74         if (siloText == null) {
75             throw new IllegalArgumentException("Could not retrieve silo of the selected lab : "
76                     + submission.getTimeslot().getLab().getLab().toString());
77         }
78         LOGGER.info(EELFLoggerDelegate.applicationLogger,
79                 "Updating submission with id: " + submission.getSubmissionId());
80         submission.setSubmissionStatus(SubmissionStatus.Completed);
81         submissionHelper.saveSubmission(submission);
82         ValidationDbTestResult vDbResult = vTestResultDAO.getValidationTestResult(submission);
83         if (vDbResult != null) {
84             ValidationNexusTestResult vNexusResult = iService.getResult(vDbResult.getBlueprintName(),
85                     vDbResult.getVersion(), vDbResult.getLab().getLab(), jnksJobNotify.getTimestamp());
86             if (vNexusResult != null) {
87                 List<ValidationNexusTestResult> vNexusResults = new ArrayList<ValidationNexusTestResult>();
88                 vNexusResults.add(vNexusResult);
89                 dbAdapter.storeResultInDb(vNexusResults);
90             }
91         }
92         dbAdapter.updateTimestamp(jnksJobNotify);
93     }
94
95 }