diff options
author | Jesus Fernandez <jesus.fernandez@qt.io> | 2018-01-18 11:59:59 +0100 |
---|---|---|
committer | Jesus Fernandez <Jesus.Fernandez@qt.io> | 2018-01-18 17:01:42 +0000 |
commit | cd3d1278f012b8f6b259305fd06006be7f825c99 (patch) | |
tree | b6c8c56cab52241d2428a0aeceda7061ac1cd337 | |
parent | a3495e515da0ffee896888cfa0f2d364b129ed2c (diff) |
Add a basic OAuth2 test
Change-Id: I62161dfdfd707a9e943516dde0c62abbb471ebad
Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
-rw-r--r-- | tests/auto/auto.pro | 1 | ||||
-rw-r--r-- | tests/auto/oauth2/oauth2.pro | 8 | ||||
-rw-r--r-- | tests/auto/oauth2/tst_oauth2.cpp | 100 |
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" |