summaryrefslogtreecommitdiff
path: root/test/UnitHosting.cpp
diff options
context:
space:
mode:
authorMiklos Vajna <vmiklos@collabora.com>2020-01-17 08:50:15 +0100
committerMiklos Vajna <vmiklos@collabora.com>2020-01-17 09:16:41 +0100
commite2fa8c43a1cc800016ec4a2ca5ba0da5c322ca47 (patch)
treeae0890e776d6e28dda494b78f38f7f66a3c85cb7 /test/UnitHosting.cpp
parent0cc4977abdbb0225c8c1a5f59b5bc00891463775 (diff)
Convert some of the integration-http-server tests to new-style ones
So that they are in-process, which means it's easier to debug when they fail. Change-Id: I164b97be0bc487a02d4b2a872b9c0e40791056cd Reviewed-on: https://gerrit.libreoffice.org/c/online/+/86951 Tested-by: Jenkins CollaboraOffice <jenkinscollaboraoffice@gmail.com> Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
Diffstat (limited to 'test/UnitHosting.cpp')
-rw-r--r--test/UnitHosting.cpp150
1 files changed, 150 insertions, 0 deletions
diff --git a/test/UnitHosting.cpp b/test/UnitHosting.cpp
new file mode 100644
index 000000000..9c3825727
--- /dev/null
+++ b/test/UnitHosting.cpp
@@ -0,0 +1,150 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+
+#include <memory>
+#include <ostream>
+#include <set>
+#include <string>
+
+#include <Poco/DOM/AutoPtr.h>
+#include <Poco/DOM/DOMParser.h>
+#include <Poco/DOM/Document.h>
+#include <Poco/DOM/NodeList.h>
+#include <Poco/Exception.h>
+#include <Poco/RegularExpression.h>
+#include <Poco/URI.h>
+#include <cppunit/TestAssert.h>
+
+#include <Png.hpp>
+#include <Unit.hpp>
+#include <helpers.hpp>
+
+// Include config.h last, so the test server URI is still HTTP, even in SSL builds.
+#include <config.h>
+
+class LOOLWebSocket;
+
+/// Test suite for /hosting, etc.
+class UnitHosting : public UnitWSD
+{
+ TestResult testDiscovery();
+ TestResult testCapabilities();
+
+public:
+ void invokeTest() override;
+};
+
+UnitBase::TestResult UnitHosting::testDiscovery()
+{
+ Poco::URI uri(helpers::getTestServerURI());
+ std::unique_ptr<Poco::Net::HTTPClientSession> session(helpers::createSession(uri));
+
+ Poco::Net::HTTPRequest request(Poco::Net::HTTPRequest::HTTP_GET, "/hosting/discovery");
+ session->sendRequest(request);
+
+ Poco::Net::HTTPResponse response;
+ session->receiveResponse(response);
+ CPPUNIT_ASSERT_EQUAL(Poco::Net::HTTPResponse::HTTP_OK, response.getStatus());
+ CPPUNIT_ASSERT_EQUAL(std::string("text/xml"), response.getContentType());
+
+ Poco::Net::HTTPRequest request2(Poco::Net::HTTPRequest::HTTP_GET, "/hosting/discovery/");
+ session->sendRequest(request2);
+
+ Poco::Net::HTTPResponse response2;
+ session->receiveResponse(response2);
+ CPPUNIT_ASSERT_EQUAL(Poco::Net::HTTPResponse::HTTP_OK, response2.getStatus());
+ CPPUNIT_ASSERT_EQUAL(std::string("text/xml"), response2.getContentType());
+ return TestResult::Ok;
+}
+
+UnitBase::TestResult UnitHosting::testCapabilities()
+{
+ Poco::URI uri(helpers::getTestServerURI());
+ std::unique_ptr<Poco::Net::HTTPClientSession> session(helpers::createSession(uri));
+
+ // Get discovery first and extract the urlsrc of the capabilities end point
+ std::string capabilitiesURI;
+ {
+ Poco::Net::HTTPRequest request(Poco::Net::HTTPRequest::HTTP_GET, "/hosting/discovery");
+ session->sendRequest(request);
+
+ Poco::Net::HTTPResponse response;
+ std::istream& rs = session->receiveResponse(response);
+ CPPUNIT_ASSERT_EQUAL(Poco::Net::HTTPResponse::HTTP_OK, response.getStatus());
+ CPPUNIT_ASSERT_EQUAL(std::string("text/xml"), response.getContentType());
+
+ std::string discoveryXML;
+ Poco::StreamCopier::copyToString(rs, discoveryXML);
+
+ Poco::XML::DOMParser parser;
+ Poco::XML::AutoPtr<Poco::XML::Document> docXML = parser.parseString(discoveryXML);
+ Poco::XML::AutoPtr<Poco::XML::NodeList> listNodes = docXML->getElementsByTagName("action");
+ bool foundCapabilities = false;
+ for (unsigned long index = 0; index < listNodes->length(); ++index)
+ {
+ Poco::XML::Element* elem = static_cast<Poco::XML::Element*>(listNodes->item(index));
+ Poco::XML::Element* parent = elem->parentNode()
+ ? static_cast<Poco::XML::Element*>(elem->parentNode())
+ : nullptr;
+ if (parent && parent->getAttribute("name") == "Capabilities")
+ {
+ foundCapabilities = true;
+ capabilitiesURI = elem->getAttribute("urlsrc");
+ break;
+ }
+ }
+
+ CPPUNIT_ASSERT(foundCapabilities);
+ CPPUNIT_ASSERT_EQUAL(uri.toString() + CAPABILITIES_END_POINT, capabilitiesURI);
+ }
+
+ // Then get the capabilities json
+ {
+ Poco::Net::HTTPRequest request(Poco::Net::HTTPRequest::HTTP_GET, CAPABILITIES_END_POINT);
+ session->sendRequest(request);
+
+ Poco::Net::HTTPResponse response;
+ std::istream& rs = session->receiveResponse(response);
+ CPPUNIT_ASSERT_EQUAL(Poco::Net::HTTPResponse::HTTP_OK, response.getStatus());
+ CPPUNIT_ASSERT_EQUAL(std::string("application/json"), response.getContentType());
+
+ std::ostringstream oss;
+ Poco::StreamCopier::copyStream(rs, oss);
+ std::string responseString = oss.str();
+
+ Poco::JSON::Parser parser;
+ Poco::Dynamic::Var jsonFile = parser.parse(responseString);
+ Poco::JSON::Object::Ptr features = jsonFile.extract<Poco::JSON::Object::Ptr>();
+ CPPUNIT_ASSERT(features);
+ CPPUNIT_ASSERT(features->has("convert-to"));
+
+ Poco::JSON::Object::Ptr convert_to
+ = features->get("convert-to").extract<Poco::JSON::Object::Ptr>();
+ CPPUNIT_ASSERT(convert_to->has("available"));
+ CPPUNIT_ASSERT(convert_to->get("available"));
+ }
+ return TestResult::Ok;
+}
+
+void UnitHosting::invokeTest()
+{
+ UnitBase::TestResult result = testDiscovery();
+ if (result != TestResult::Ok)
+ exitTest(result);
+
+ result = testCapabilities();
+ if (result != TestResult::Ok)
+ exitTest(result);
+
+ exitTest(TestResult::Ok);
+}
+
+UnitBase* unit_create_wsd(void) { return new UnitHosting(); }
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */