2 <div class="wrapper wrapper-content animated fadeIn">
3 <div class="row" style="margin-bottom: 20px;">
4 <div class="col-md-12">
5 <ol class="breadcrumb" style="padding-left: 20px; font-size: 17px;">
7 <router-link to="/" >root</router-link>
10 <router-link :to="{ path: '/testcase', query: { name: sname }}"><b>{{this.$route.query.name}}</b></router-link>
15 <div id="page-content" style="" class="row">
16 <div class="col-lg-12">
18 <div class="ibox-title">
19 <h5 style="font-size:26px;margin-top: -3px;">Test Case</h5>
20 <div class="ibox-tools">
21 <button class="btn btn-info btn-sm my-button-sm" type="button" v-on:click="runMultiTestcase()">Run</button>
22 <button class="btn btn-success btn-sm my-button-sm" type="button" v-on:click="create()">Create</button>
23 <button class="btn btn-danger btn-sm my-button-sm" v-on:click="deleteCases()" type="button">Delete</button>
24 <a class="collapse-link">
25 <i class="fa fa-chevron-up"></i>
27 <a class="fullscreen-link">
28 <i class="fa fa-expand"></i>
32 <div class="ibox-content" style="text-align:center;">
33 <table class="my-table table table-bordered" cellspacing="0" cellpadding="0" style="text-align: center;">
36 <td class="checkbox1" style="width:20px"><input type="checkbox" v-model="selectAll"> All</td>
37 <td class="smallbox" style="with:250px;">TestCase Name</td>
41 <tr v-for="testcase in testcases">
42 <td><input class="checkbox1" style="width:20px" type="checkbox" v-model="selected" :value="testcase.testcase"> </td>
43 <td class="smallbox" style="with:250px;"><router-link :to="{ path: '/content', query: { suiteName: sname, caseName: testcase.testcase } }">{{testcase.testcase}}</router-link></td>
46 <tfoot id="create-box" style="display: none">
48 <td class="checkbox1" style="width:20px"><input type="checkbox"> </td>
49 <td class="smallbox" style="with:250px;"><input type="text" v-model="newCase" @keydown.enter="additem" ></td>
58 <div class="row" v-show="runYet">
59 <div class="col-lg-12">
61 <div class="ibox-title">
62 <h5 style="font-size:26px;margin-top: -3px;">Workflow</h5>
63 <div class="ibox-tools">
64 <a class="collapse-link">
65 <i class="fa fa-chevron-up"></i>
67 <a class="fullscreen-link">
68 <i class="fa fa-expand"></i>
72 <div class="ibox-content" style="padding-top: 30px;">
73 <div id="executing" class="row" style="padding: 0 30px 60px;">
74 <div class="col-md-offset-2 col-md-8">
75 <div class="table-responsive">
76 <table class="table text-center" style="margin-top: 30px;">
79 <th class="text-center">#</th>
80 <th class="text-center">testcase</th>
81 <th class="text-center">status</th>
82 <th class="text-center">operation</th>
86 <tr v-for="testcase in runTestcases">
87 <td>{{ testcase.id }}</td>
88 <td>{{ testcase.testcase }}</td>
89 <td><span class="badge" v-bind:class="'badge-' + statusClass(testcase.status)">{{ testcase.status }}</span></td>
91 <div style="display: inline-block;min-width: 130px;">
92 <button class="btn btn-primary btn-outline btn-xs fadeIn" v-on:click="runTestcase()" v-show="testcase.status == 'failed'">rerun</button>
93 <button class="btn btn-primary btn-outline btn-xs fadeIn" v-on:click="runNextCase($event.target)" v-show="testcase.status == 'failed'">run next one</button>
102 <hr class="hr-line-solid">
103 <div class="row" style="margin-top: 60px;">
104 <wfresult v-bind:workflowId="workflowId" v-bind:wfloading='wfloading' v-bind:wfJson='wfJson' v-on:wfComplete="wfComplete = $event"></wfresult>
113 import wfresult from './workflow_graph/wfresult.vue'
114 import showMessage from './message/showMessage.js'
120 sname: this.$route.query.name,
133 created: function() {
135 var msgTitle = "GET -- TESTCASES";
136 var errorInfo = "Failed to get testcase list.";
138 url: this.global.SERVER_ADDR + "testsuite/content",
141 suiteName: this.$route.query.name
143 success:function (data) {
144 if(data['code'] == 200) {
145 self.testcases = data['result'];
147 showMessage(data['code'], msgTitle, errorInfo, data['error']);
150 error: function(obj, status, msg) {
151 showMessage(status, msgTitle, errorInfo, msg);
158 return this.testcases ? this.selected.length == this.testcases.length : false;
160 set: function (value) {
163 this.testcases.forEach(function (testcase) {
164 selected.push(testcase.testcase);
167 this.selected = selected;
172 create: function () {
173 var cbox = document.getElementById("create-box");
174 cbox.style.display = "table-footer-group";
176 additem: function () {
178 var msgTitle = "CREATE -- TESTCASE";
179 const caseName = self.newCase.trim();
183 url: this.global.SERVER_ADDR + "testcase/new",
186 suiteName: self.sname,
189 success:function (data) {
190 if(data['code'] == 200){
191 self.testcases.push({
192 id: self.testcases.length + 1 ,
195 showMessage(data['code'], msgTitle, "Create <strong>" + caseName + "</strong> succesfully!");
197 showMessage(data['code'], msgTitle, "Failed to create <strong>" + caseName + "</strong>!", data['error']);
200 error: function(obj, status, msg) {
201 showMessage(status, msgTitle, "Failed to create <strong>" + caseName + "</strong>!", msg);
205 var cbox = document.getElementById("create-box");
206 cbox.style.display = "none";
209 deleteCases:function () {
211 var msgTitle = "DELETE -- TESTCASE";
212 var deleteArr = self.selected.slice(0);
213 self.testcases = self.testcases.filter(item => {
214 for(var i in deleteArr) {
215 if(item.testcase == deleteArr[i]) {
222 for(var i in deleteArr)
225 url: this.global.SERVER_ADDR + "testcase/delete",
228 suiteName: self.sname,
229 caseName: deleteArr[i]
231 success: function(data) {
232 if(data['code'] == 200){
233 showMessage(data['code'], msgTitle, "Delete <strong>" + deleteArr[i] + "</strong> succesfully!");
235 showMessage(data['code'], msgTitle, "Failed to delete <strong>" + deleteArr[i] + "</strong>!", data['error']);
238 error: function(obj, status, msg) {
239 showMessage(status, msgTitle, "Failed to delete <strong>" + deleteArr[i] + "</strong>!", msg);
244 runMultiTestcase: function() {
246 var msgTitle = "RUN -- TESTCASES";
250 self.runTestcases = [];
251 if(self.selected.length == 0) {
252 showMessage("warning", msgTitle, "please select one!");
255 for(var i=0; i < self.selected.length; i++) {
256 var testcaseItem = {'id': i, 'testcase': '', 'status': "waiting"};
257 testcaseItem['testcase'] = self.selected[i];
258 self.runTestcases.push(testcaseItem);
260 self.curRunningId = 0;
261 showMessage("info", msgTitle, "start to run <strong>testcases</strong>");
262 self.runOneTestcase();
264 runOneTestcase: function() {
266 var msgTitle = "RUN -- TESTCASE";
267 if (self.curRunningId == self.runTestcases.length) {
268 self.curRunningId = 0;
271 self.wfComplete = false;
272 var i = self.curRunningId;
273 self.runTestcases[i]['status'] = "running";
275 url: self.global.SERVER_ADDR + "execute/testcase",
278 "suiteName": self.sname,
279 "caseName": self.runTestcases[self.curRunningId]['testcase']
281 beforeSend: function(XHR) {
282 self.wfloading = true;
284 success: function(data) {
285 if(data['code'] == 200) {
286 self.workflowId = data['result']['workflowId'];
288 url: self.global.SERVER_ADDR + "story-content",
291 "service": self.sname,
292 "story": self.runTestcases[self.curRunningId]['testcase']
294 success: function(data) {
295 if(data['code'] == 200) {
296 self.wfJson = data['result']['content'];
298 showMessage(data['code'], msgTitle, "workflow.json get failed!");
301 error: function(obj, status, msg) {
302 showMessage(status, msgTitle, msg);
306 var i = self.curRunningId;
307 self.runTestcases[i]['status'] = "failed";
308 self.wfloading = false;
309 showMessage(data['code'], msgTitle, "Failed to run <strong>" + self.runTestcases[i]['testcase'] + "</strong>", data['error']);
312 error: function(obj, status, msg) {
313 var i = self.curRunningId;
314 self.runTestcases[i]['status'] = "failed";
315 self.wfloading = false;
316 showMessage(status, msgTitle, "Failed to run <strong>" + self.runTestcases[i]['testcase'] + "</strong>", msg);
320 statusClass: function(status) {
321 if(status == "waiting") {
324 if(status == "running") {
327 if(status == "pass") {
330 if(status == "failed") {
334 runNextCase: function(obj) {
335 $(obj).parent().css({"display": "none"});
336 var i = this.curRunningId++;
337 this.runOneTestcase();
341 wfComplete: function(val) {
342 if(val == false) return;
343 this.wfloading = false;
344 var i = this.curRunningId++;
345 this.runTestcases[i]['status'] = "pass";
346 this.runOneTestcase();