File: CReasonerEvaluationEvaluator.cpp

package info (click to toggle)
konclude 0.6.2~dfsg-6
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 26,992 kB
  • sloc: cpp: 250,898; xml: 54,573; makefile: 37; sh: 17; ansic: 3
file content (123 lines) | stat: -rw-r--r-- 4,773 bytes parent folder | download | duplicates (2)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
 *		Copyright (C) 2013, 2014, 2015 by the Konclude Developer Team.
 *
 *		This file is part of the reasoning system Konclude.
 *		For details and support, see <http://konclude.com/>.
 *
 *		Konclude is free software: you can redistribute it and/or modify it under
 *		the terms of version 2.1 of the GNU Lesser General Public License (LGPL2.1)
 *		as published by the Free Software Foundation.
 *
 *		You should have received a copy of the GNU Lesser General Public License
 *		along with Konclude. If not, see <http://www.gnu.org/licenses/>.
 *
 *		Konclude 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. For more
 *		details, see GNU Lesser General Public License.
 *
 */

#include "CReasonerEvaluationEvaluator.h"


namespace Konclude {

	namespace Test {

		namespace Evaluation {



			CReasonerEvaluationEvaluator::CReasonerEvaluationEvaluator() {
			}


			CReasonerEvaluationEvaluator::~CReasonerEvaluationEvaluator() {
			}


			bool CReasonerEvaluationEvaluator::evaluateResults(CReasonerEvaluationRequestResult* requestResult, CReasonerEvaluationTerminationResult* terminationResult, const QString& inputFileString, const QString& responseFileString, CConfiguration* config) {
				QDomDocument document = createResponseDocument();
				QDomElement responseNode = document.documentElement();
				responseNode.setAttribute("response-time",requestResult->getResponseTime());
				responseNode.setAttribute("test",inputFileString);
				if (!requestResult->getResponsedInTime()) {
					responseNode.setAttribute("timeout",1);
				} else {
					responseNode.setAttribute("timeout",0);
				}

				QDateTime dateTime = QDateTime::currentDateTime();
				responseNode.appendChild(document.createComment(QString("Executed date: %1").arg(dateTime.toString())));

				if (terminationResult->hasProcessError()) {
					responseNode.appendChild(document.createComment(QString("Reasoner error: %1").arg(terminationResult->getErrorText())));
				}

				QString output = terminationResult->getStandardOutputText();
				if (output.isEmpty()) {
					output = terminationResult->getErrorOutputText();
				}
				responseNode.appendChild(document.createComment(QString("Reasoner output:\r\n%1").arg(output)));


				QList<CReasonerEvaluationRequestResponse*>* responseList = requestResult->getResponseList();
				foreach (CReasonerEvaluationRequestResponse* response, *responseList) {
					if (response->isTimedOut()) {
						QDomElement errorElm = document.createElement("Error");
						errorElm.setAttribute("timeout",1);
						cint64 responseTime = response->getResponseTime();
						errorElm.setAttribute("response-time",responseTime);
						errorElm.setAttribute("error","timeout");
						errorElm.setAttribute("request-command",response->getRequestNode().tagName());
						responseNode.appendChild(errorElm);
					} else if (response->hasResponseError()) {
						QDomElement errorElm = document.createElement("Error");
						cint64 responseTime = response->getResponseTime();
						errorElm.setAttribute("response-time",responseTime);
						errorElm.setAttribute("error","unknown error");
						errorElm.setAttribute("request-command",response->getRequestNode().tagName());
						responseNode.appendChild(errorElm);
					} else {
						QDomElement domElm = response->getResponseNode();
						cint64 responseTime = response->getResponseTime();
						QDomNode importedNode = document.importNode(domElm,true);
						QDomElement impDomElm = importedNode.toElement();
						impDomElm.setAttribute("response-time",responseTime);
						impDomElm.setAttribute("request-command",response->getRequestNode().tagName());
						responseNode.appendChild(impDomElm);
					}
				}

				QFile file(responseFileString);
				if (file.open(QIODevice::WriteOnly)) {
					file.write(document.toByteArray());
					file.close();
				}

				return true;
			}

			QDomDocument CReasonerEvaluationEvaluator::createResponseDocument() {
				QDomDocument document;

				QString owllinkNS = "http://www.owllink.org/owllink#";
				QString owlNS = "http://www.w3.org/2002/07/owl#";

				QDomElement rootNode;

				rootNode = document.createElementNS(owllinkNS,"ResponseMessage");
				//rootNode.setAttributeNS("xsi:schemaLocation","http://www.owllink.org/owllink# http://www.owllink.org/owllink-20091116.xsd");
				rootNode.setAttributeNS("http://www.w3.org/2001/XMLSchema-instance","xsi:schemaLocation","http://www.owllink.org/owllink# http://www.owllink.org/owllink-20091116.xsd");
				rootNode.setAttribute("xmlns:owl",owlNS);
				document.appendChild(rootNode);

				return document;
			}

		}; // end namespace Evaluation

	}; // end namespace Test

}; // end namespace Konclude