fix(接口测试): sql 查询多表格式化优化

This commit is contained in:
chenjianxing 2020-11-23 20:21:56 +08:00
parent 744de357c3
commit 4190eb92fd
2 changed files with 88 additions and 37 deletions

View File

@ -7,8 +7,8 @@
<el-collapse-transition> <el-collapse-transition>
<el-tabs v-model="activeName" v-show="isActive"> <el-tabs v-model="activeName" v-show="isActive">
<el-tab-pane :class="'body-pane'" label="Body" name="body" class="pane"> <el-tab-pane :class="'body-pane'" label="Body" name="body" class="pane">
<ms-sql-result-table v-if="isSqlType" :body="response.body"/> <ms-sql-result-table v-if="isSqlType && mode == 'table'" :body="response.body"/>
<ms-code-edit v-if="!isSqlType" :mode="mode" :read-only="true" :data="response.body" :modes="modes" ref="codeEdit"/> <ms-code-edit v-if="mode != 'table'" :mode="mode" :read-only="true" :data="response.body" :modes="modes" ref="codeEdit"/>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Headers" name="headers" class="pane"> <el-tab-pane label="Headers" name="headers" class="pane">
<pre>{{ response.headers }}</pre> <pre>{{ response.headers }}</pre>
@ -21,9 +21,10 @@
<pre>{{response.vars}}</pre> <pre>{{response.vars}}</pre>
</el-tab-pane> </el-tab-pane>
<el-tab-pane v-if="activeName == 'body' && !isSqlType" :disabled="true" name="mode" class="pane assertions"> <el-tab-pane v-if="activeName == 'body'" :disabled="true" name="mode" class="pane assertions">
<template v-slot:label> <template v-slot:label>
<ms-dropdown :commands="modes" :default-command="mode" @command="modeChange"/> <ms-dropdown v-if="!isSqlType" :commands="modes" :default-command="mode" @command="modeChange"/>
<ms-dropdown v-if="isSqlType" :commands="sqlModes" :default-command="mode" @command="sqlModeChange"/>
</template> </template>
</el-tab-pane> </el-tab-pane>
@ -59,6 +60,7 @@ export default {
isActive: true, isActive: true,
activeName: "body", activeName: "body",
modes: ['text', 'json', 'xml', 'html'], modes: ['text', 'json', 'xml', 'html'],
sqlModes: ['text', 'table'],
mode: BODY_FORMAT.TEXT mode: BODY_FORMAT.TEXT
} }
}, },
@ -69,6 +71,9 @@ export default {
}, },
modeChange(mode) { modeChange(mode) {
this.mode = mode; this.mode = mode;
},
sqlModeChange(mode) {
this.mode = mode;
} }
}, },

View File

@ -1,10 +1,13 @@
<template> <template>
<div>
<el-table <el-table
:data="tableData" v-for="(table, index) in tables"
:key="index"
:data="table.tableData"
border border
size="mini" size="mini"
highlight-current-row> highlight-current-row>
<el-table-column v-for="(title, index) in titles" :key="index" :label="title" min-width="15%"> <el-table-column v-for="(title, index) in table.titles" :key="index" :label="title" min-width="150px">
<template v-slot:default="scope"> <template v-slot:default="scope">
<el-popover <el-popover
placement="top" placement="top"
@ -17,6 +20,7 @@
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</div>
</template> </template>
<script> <script>
@ -24,7 +28,7 @@
name: "MsSqlResultTable", name: "MsSqlResultTable",
data() { data() {
return { return {
tableData: [], tables: [],
titles: [] titles: []
} }
}, },
@ -36,29 +40,71 @@
return; return;
} }
let rowArry = this.body.split("\n"); let rowArry = this.body.split("\n");
let title; this.getTableData(rowArry);
if (this.tables.length > 1) {
for (let i = 0; i < this.tables.length; i++) {
if (this.tables[i].titles.length === 1 && i < this.tables.length - 1) {
this.tables[i].tableData.splice(this.tables[i].tableData.length - 1, 1);
}
}
let lastTable = this.tables[this.tables.length - 1];
if (lastTable.titles.length === 1) {
if (lastTable.tableData.length > 4) {
lastTable.tableData.splice(lastTable.tableData.length - 4, 4);
} else {
this.tables.splice(this.tables.length - 1, 1);
}
} else {
this.tables.splice(this.tables.length - 1, 1);
}
} else {
let table = this.tables[0];
table.tableData.splice(table.tableData.length - 4, 4);
}
},
methods: {
getTableData(rowArry) {
let titles;
let result = []; let result = [];
for (let i = 0; i < rowArry.length; i++) { for (let i = 0; i < rowArry.length; i++) {
let colArray = rowArry[i].split("\t"); let colArray = rowArry[i].split("\t");
if (i === 0) { if (i === 0) {
title = colArray; titles = colArray;
} else {
if (colArray.length != titles.length) {
//
if (colArray.length === 1 && colArray[0] === '') {
this.getTableData(rowArry.slice(i + 1));
} else {
this.getTableData(rowArry.slice(i));
}
break;
} else { } else {
let item = {}; let item = {};
for (let j = 0; j < colArray.length; j++) { for (let j = 0; j < colArray.length; j++) {
item[title[j]] = (colArray[j] ? colArray[j] : ""); item[titles[j]] = (colArray[j] ? colArray[j] : "");
} }
result.push(item); result.push(item);
} }
} }
this.titles = title; }
this.tableData = result;
this.tableData.splice(this.tableData.length - 3, 3); this.tables.splice(0, 0, {
titles: titles,
tableData: result
});
}
} }
} }
</script> </script>
<style scoped> <style scoped>
.el-table {
margin-bottom: 20px;
}
.el-table >>> .cell { .el-table >>> .cell {
white-space: nowrap; white-space: nowrap;
} }