summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJesus Fernandez <jesus.fernandez@qt.io>2018-01-18 11:59:59 +0100
committerJesus Fernandez <Jesus.Fernandez@qt.io>2018-01-18 17:01:42 +0000
commitcd3d1278f012b8f6b259305fd06006be7f825c99 (patch)
treeb6c8c56cab52241d2428a0aeceda7061ac1cd337
parenta3495e515da0ffee896888cfa0f2d364b129ed2c (diff)
Add a basic OAuth2 test
Change-Id: I62161dfdfd707a9e943516dde0c62abbb471ebad Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
-rw-r--r--tests/auto/auto.pro1
-rw-r--r--tests/auto/oauth2/oauth2.pro8
-rw-r--r--tests/auto/oauth2/tst_oauth2.cpp100
3 files changed, 109 insertions, 0 deletions
diff --git a/tests/auto/auto.pro b/tests/auto/auto.pro
index 41f3293..a0bbb36 100644
--- a/tests/auto/auto.pro
+++ b/tests/auto/auto.pro
@@ -3,6 +3,7 @@ TEMPLATE = subdirs
SUBDIRS += \
cmake \
oauth1 \
+ oauth2 \
oauth1signature \
oauthhttpserverreplyhandler
diff --git a/tests/auto/oauth2/oauth2.pro b/tests/auto/oauth2/oauth2.pro
new file mode 100644
index 0000000..74f3fda
--- /dev/null
+++ b/tests/auto/oauth2/oauth2.pro
@@ -0,0 +1,8 @@
+TEMPLATE = app
+CONFIG += testcase
+TARGET = tst_oauth2
+SOURCES += tst_oauth2.cpp
+
+include(../shared/shared.pri)
+
+QT = core core-private network networkauth networkauth-private testlib
diff --git a/tests/auto/oauth2/tst_oauth2.cpp b/tests/auto/oauth2/tst_oauth2.cpp
new file mode 100644
index 0000000..826be06
--- /dev/null
+++ b/tests/auto/oauth2/tst_oauth2.cpp
@@ -0,0 +1,100 @@
+/****************************************************************************
+**
+** Copyright (C) 2017 The Qt Company Ltd.
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:GPL-EXCEPT$
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and The Qt Company. For licensing terms
+** and conditions see https://www.qt.io/terms-conditions. For further
+** information use the contact form at https://www.qt.io/contact-us.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3 as published by the Free Software
+** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
+** included in the packaging of this file. Please review the following
+** information to ensure the GNU General Public License requirements will
+** be met: https://www.gnu.org/licenses/gpl-3.0.html.
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include <QtTest>
+
+#include <QtNetworkAuth/qabstractoauthreplyhandler.h>
+#include <QtNetworkAuth/qoauth2authorizationcodeflow.h>
+
+#include "webserver.h"
+
+class tst_OAuth2 : public QObject
+{
+ Q_OBJECT
+
+private Q_SLOTS:
+ void getToken();
+};
+
+struct ReplyHandler : QAbstractOAuthReplyHandler
+{
+ QString callback() const override
+ {
+ return QLatin1String("test");
+ }
+
+ void networkReplyFinished(QNetworkReply *reply) override
+ {
+ QVariantMap data;
+ const auto items = QUrlQuery(reply->readAll()).queryItems();
+ for (const auto &pair : items)
+ data.insert(pair.first, pair.second);
+ Q_EMIT tokensReceived(data);
+ }
+
+ void emitCallbackReceived(const QVariantMap &data)
+ {
+ Q_EMIT callbackReceived(data);
+ }
+};
+
+void tst_OAuth2::getToken()
+{
+ WebServer webServer([](const WebServer::HttpRequest &request, QTcpSocket *socket) {
+ if (request.url.path() == QLatin1String("/accessToken")) {
+ const QString text = "access_token=token&token_type=bearer";
+ const QByteArray replyMessage {
+ "HTTP/1.0 200 OK\r\n"
+ "Content-Type: application/x-www-form-urlencoded; charset=\"utf-8\"\r\n"
+ "Content-Length: " + QByteArray::number(text.size()) + "\r\n\r\n"
+ + text.toUtf8()
+ };
+ socket->write(replyMessage);
+ }
+ });
+ QOAuth2AuthorizationCodeFlow oauth2;
+ oauth2.setAuthorizationUrl(webServer.url(QLatin1String("authorization")));
+ oauth2.setAccessTokenUrl(webServer.url(QLatin1String("accessToken")));
+ auto replyHandler = new ReplyHandler;
+ oauth2.setReplyHandler(replyHandler);
+ connect(&oauth2, &QOAuth2AuthorizationCodeFlow::authorizeWithBrowser, [&](const QUrl &url) {
+ const QUrlQuery query(url.query());
+ replyHandler->emitCallbackReceived(QVariantMap {
+ { QLatin1String("code"), QLatin1String("test") },
+ { QLatin1String("state"),
+ query.queryItemValue(QLatin1String("state")) }
+ });
+ });
+ QSignalSpy grantedSpy(&oauth2, &QOAuth2AuthorizationCodeFlow::granted);
+ oauth2.grant();
+ QTRY_COMPARE(grantedSpy.count(), 1);
+ QCOMPARE(oauth2.token(), QLatin1String("token"));
+}
+
+QTEST_MAIN(tst_OAuth2)
+#include "tst_oauth2.moc"