Skip to content

Commit

Permalink
[RD-35945] Added bdt methods to set request headers and basic auth
Browse files Browse the repository at this point in the history
  • Loading branch information
Mathew Seymour committed Aug 12, 2019
1 parent a0accb5 commit 71ba0d2
Show file tree
Hide file tree
Showing 4 changed files with 90 additions and 2 deletions.
17 changes: 16 additions & 1 deletion browserdebuggertools/chrome/interface.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import contextlib
import time
import logging
from base64 import b64decode
from base64 import b64decode, b64encode

from browserdebuggertools.sockethandler import SocketHandler
from browserdebuggertools.exceptions import (
Expand Down Expand Up @@ -215,3 +215,18 @@ def emulate_network_conditions(self, latency, download, upload, offline=False):
}

return self.execute("Network", "emulateNetworkConditions", network_conditions)

def set_basic_auth(self, username, password):
"""
Creates a basic type Authorization header from the username and password strings
and applies it to all requests
"""
auth = "Basic " + b64encode("%s:%s" % (username, password))
self.set_request_headers({"Authorization": auth})

def set_request_headers(self, headers):
"""
The specified headers are applied to all requests
:param headers: A dictionary of the form {"headerKey": "headerValue"}
"""
self.execute("Network", "setExtraHTTPHeaders", {"headers": headers})
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@

setup(
name="browserdebuggertools",
version="3.1.0",
version="3.2.0",
packages=PACKAGES,
install_requires=requires,
license="GNU General Public License v3",
Expand Down
31 changes: 31 additions & 0 deletions tests/e2etests/chrome/test_interface.py
Original file line number Diff line number Diff line change
Expand Up @@ -236,3 +236,34 @@ class Test_ChromeInterface_emulate_network_conditions_headless(
HeadlessChromeInterfaceTest, ChromeInterface_emulate_network_conditions, TestCase
):
pass


class ChromeInterface_set_basic_auth(object):

def test_standard_auth_page(self):

self.devtools_client.enable_domain("Network")
url = "http://username:password@localhost:%s/auth_challenge" % self.testSite.port
self.devtools_client.navigate(url=url)
self._assert_dom_complete()

responses_received = []
for event in self.devtools_client.get_events("Network"):
if event.get("method") == "Network.responseReceived":
responses_received.append(event["params"]["response"]["status"])

self.assertTrue(len(responses_received) >= 2) # Headed browser creates extra requests
self.assertIn(200, responses_received)
self.assertNotIn(401, responses_received)


class Test_ChromeInterface_set_baic_auth_headed(
HeadedChromeInterfaceTest, ChromeInterface_set_basic_auth, TestCase
):
pass


class Test_ChromeInterface_set_baic_auth_headless(
HeadlessChromeInterfaceTest, ChromeInterface_set_basic_auth, TestCase
):
pass
42 changes: 42 additions & 0 deletions tests/e2etests/testsite/start.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import multiprocessing
from base64 import b64decode

import time

import cherrypy
Expand Down Expand Up @@ -35,6 +37,46 @@ def javascript_file(self, response_time=None):
def big_body(self, size=1000000):
return "T" * size

@cherrypy.expose
def auth_challenge(self, authorized_username="username", authorized_password="password",
response_body=None):

if self.is_authenticated(authorized_username, authorized_password):

if response_body:
return response_body

return """
<html>
<head><script src="/auth_challenge?response_body=null"></script></head>
<body>
Authorized
</body>
</html>
"""
cherrypy.response.headers["WWW-Authenticate"] = "basic"
cherrypy.response.status = 401
return "Need to authorize"

@staticmethod
def is_authenticated(authorized_username, authorized_password):

if "Authorization" in cherrypy.request.headers:

this_username, this_password = tuple(
b64decode(cherrypy.request.headers["Authorization"].split("Basic ")[1]).split(":")
)

if authorized_username and this_username != authorized_username:
return False

if authorized_password and this_password != authorized_password:
return False

return True

return False


class Server(object):

Expand Down

0 comments on commit 71ba0d2

Please sign in to comment.