Extend Request Parameters to add Body & Method (#325)
parent
e3bcd8c9bf
commit
dfcae4ee64
@ -1,80 +0,0 @@
|
|||||||
import json
|
|
||||||
import time
|
|
||||||
from flask import url_for
|
|
||||||
from . util import set_original_response, set_modified_response, live_server_setup
|
|
||||||
|
|
||||||
# Hard to just add more live server URLs when one test is already running (I think)
|
|
||||||
# So we add our test here (was in a different file)
|
|
||||||
def test_headers_in_request(client, live_server):
|
|
||||||
live_server_setup(live_server)
|
|
||||||
|
|
||||||
# Add our URL to the import page
|
|
||||||
test_url = url_for('test_headers', _external=True)
|
|
||||||
|
|
||||||
# Add the test URL twice, we will check
|
|
||||||
res = client.post(
|
|
||||||
url_for("import_page"),
|
|
||||||
data={"urls": test_url},
|
|
||||||
follow_redirects=True
|
|
||||||
)
|
|
||||||
assert b"1 Imported" in res.data
|
|
||||||
|
|
||||||
res = client.post(
|
|
||||||
url_for("import_page"),
|
|
||||||
data={"urls": test_url},
|
|
||||||
follow_redirects=True
|
|
||||||
)
|
|
||||||
assert b"1 Imported" in res.data
|
|
||||||
|
|
||||||
cookie_header = '_ga=GA1.2.1022228332; cookie-preferences=analytics:accepted;'
|
|
||||||
|
|
||||||
|
|
||||||
# Add some headers to a request
|
|
||||||
res = client.post(
|
|
||||||
url_for("edit_page", uuid="first"),
|
|
||||||
data={
|
|
||||||
"url": test_url,
|
|
||||||
"tag": "",
|
|
||||||
"fetch_backend": "html_requests",
|
|
||||||
"headers": "xxx:ooo\ncool:yeah\r\ncookie:"+cookie_header},
|
|
||||||
follow_redirects=True
|
|
||||||
)
|
|
||||||
assert b"Updated watch." in res.data
|
|
||||||
|
|
||||||
|
|
||||||
# Give the thread time to pick up the first version
|
|
||||||
time.sleep(5)
|
|
||||||
|
|
||||||
# The service should echo back the request headers
|
|
||||||
res = client.get(
|
|
||||||
url_for("preview_page", uuid="first"),
|
|
||||||
follow_redirects=True
|
|
||||||
)
|
|
||||||
|
|
||||||
# Flask will convert the header key to uppercase
|
|
||||||
assert b"Xxx:ooo" in res.data
|
|
||||||
assert b"Cool:yeah" in res.data
|
|
||||||
|
|
||||||
# The test call service will return the headers as the body
|
|
||||||
from html import escape
|
|
||||||
assert escape(cookie_header).encode('utf-8') in res.data
|
|
||||||
|
|
||||||
time.sleep(5)
|
|
||||||
|
|
||||||
# Re #137 - Examine the JSON index file, it should have only one set of headers entered
|
|
||||||
watches_with_headers = 0
|
|
||||||
with open('test-datastore/url-watches.json') as f:
|
|
||||||
app_struct = json.load(f)
|
|
||||||
for uuid in app_struct['watching']:
|
|
||||||
if (len(app_struct['watching'][uuid]['headers'])):
|
|
||||||
watches_with_headers += 1
|
|
||||||
|
|
||||||
# Should be only one with headers set
|
|
||||||
assert watches_with_headers==1
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,211 @@
|
|||||||
|
import json
|
||||||
|
import time
|
||||||
|
from flask import url_for
|
||||||
|
from . util import set_original_response, set_modified_response, live_server_setup
|
||||||
|
|
||||||
|
def test_setup(live_server):
|
||||||
|
live_server_setup(live_server)
|
||||||
|
|
||||||
|
# Hard to just add more live server URLs when one test is already running (I think)
|
||||||
|
# So we add our test here (was in a different file)
|
||||||
|
def test_headers_in_request(client, live_server):
|
||||||
|
# Add our URL to the import page
|
||||||
|
test_url = url_for('test_headers', _external=True)
|
||||||
|
|
||||||
|
# Add the test URL twice, we will check
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
cookie_header = '_ga=GA1.2.1022228332; cookie-preferences=analytics:accepted;'
|
||||||
|
|
||||||
|
|
||||||
|
# Add some headers to a request
|
||||||
|
res = client.post(
|
||||||
|
url_for("edit_page", uuid="first"),
|
||||||
|
data={
|
||||||
|
"url": test_url,
|
||||||
|
"tag": "",
|
||||||
|
"fetch_backend": "html_requests",
|
||||||
|
"headers": "xxx:ooo\ncool:yeah\r\ncookie:"+cookie_header},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"Updated watch." in res.data
|
||||||
|
|
||||||
|
|
||||||
|
# Give the thread time to pick up the first version
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
# The service should echo back the request headers
|
||||||
|
res = client.get(
|
||||||
|
url_for("preview_page", uuid="first"),
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
|
||||||
|
# Flask will convert the header key to uppercase
|
||||||
|
assert b"Xxx:ooo" in res.data
|
||||||
|
assert b"Cool:yeah" in res.data
|
||||||
|
|
||||||
|
# The test call service will return the headers as the body
|
||||||
|
from html import escape
|
||||||
|
assert escape(cookie_header).encode('utf-8') in res.data
|
||||||
|
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
# Re #137 - Examine the JSON index file, it should have only one set of headers entered
|
||||||
|
watches_with_headers = 0
|
||||||
|
with open('test-datastore/url-watches.json') as f:
|
||||||
|
app_struct = json.load(f)
|
||||||
|
for uuid in app_struct['watching']:
|
||||||
|
if (len(app_struct['watching'][uuid]['headers'])):
|
||||||
|
watches_with_headers += 1
|
||||||
|
|
||||||
|
# Should be only one with headers set
|
||||||
|
assert watches_with_headers==1
|
||||||
|
|
||||||
|
def test_body_in_request(client, live_server):
|
||||||
|
# Add our URL to the import page
|
||||||
|
test_url = url_for('test_body', _external=True)
|
||||||
|
|
||||||
|
# Add the test URL twice, we will check
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
body_value = 'Test Body Value'
|
||||||
|
|
||||||
|
# Attempt to add a body with a GET method
|
||||||
|
res = client.post(
|
||||||
|
url_for("edit_page", uuid="first"),
|
||||||
|
data={
|
||||||
|
"url": test_url,
|
||||||
|
"tag": "",
|
||||||
|
"method": "GET",
|
||||||
|
"fetch_backend": "html_requests",
|
||||||
|
"body": "invalid"},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"Body must be empty when Request Method is set to GET" in res.data
|
||||||
|
|
||||||
|
# Add a properly formatted body with a proper method
|
||||||
|
res = client.post(
|
||||||
|
url_for("edit_page", uuid="first"),
|
||||||
|
data={
|
||||||
|
"url": test_url,
|
||||||
|
"tag": "",
|
||||||
|
"method": "POST",
|
||||||
|
"fetch_backend": "html_requests",
|
||||||
|
"body": body_value},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"Updated watch." in res.data
|
||||||
|
|
||||||
|
# Give the thread time to pick up the first version
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
# The service should echo back the body
|
||||||
|
res = client.get(
|
||||||
|
url_for("preview_page", uuid="first"),
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
|
||||||
|
# Check if body returned contains the specified data
|
||||||
|
assert str.encode(body_value) in res.data
|
||||||
|
|
||||||
|
watches_with_body = 0
|
||||||
|
with open('test-datastore/url-watches.json') as f:
|
||||||
|
app_struct = json.load(f)
|
||||||
|
for uuid in app_struct['watching']:
|
||||||
|
if app_struct['watching'][uuid]['body']==body_value:
|
||||||
|
watches_with_body += 1
|
||||||
|
|
||||||
|
# Should be only one with body set
|
||||||
|
assert watches_with_body==1
|
||||||
|
|
||||||
|
def test_method_in_request(client, live_server):
|
||||||
|
# Add our URL to the import page
|
||||||
|
test_url = url_for('test_method', _external=True)
|
||||||
|
|
||||||
|
# Add the test URL twice, we will check
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
res = client.post(
|
||||||
|
url_for("import_page"),
|
||||||
|
data={"urls": test_url},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"1 Imported" in res.data
|
||||||
|
|
||||||
|
# Attempt to add a method which is not valid
|
||||||
|
res = client.post(
|
||||||
|
url_for("edit_page", uuid="first"),
|
||||||
|
data={
|
||||||
|
"url": test_url,
|
||||||
|
"tag": "",
|
||||||
|
"fetch_backend": "html_requests",
|
||||||
|
"method": "invalid"},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"Not a valid choice" in res.data
|
||||||
|
|
||||||
|
# Add a properly formatted body
|
||||||
|
res = client.post(
|
||||||
|
url_for("edit_page", uuid="first"),
|
||||||
|
data={
|
||||||
|
"url": test_url,
|
||||||
|
"tag": "",
|
||||||
|
"fetch_backend": "html_requests",
|
||||||
|
"method": "PATCH"},
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
assert b"Updated watch." in res.data
|
||||||
|
|
||||||
|
# Give the thread time to pick up the first version
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
# The service should echo back the request verb
|
||||||
|
res = client.get(
|
||||||
|
url_for("preview_page", uuid="first"),
|
||||||
|
follow_redirects=True
|
||||||
|
)
|
||||||
|
|
||||||
|
# The test call service will return the verb as the body
|
||||||
|
assert b"PATCH" in res.data
|
||||||
|
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
watches_with_method = 0
|
||||||
|
with open('test-datastore/url-watches.json') as f:
|
||||||
|
app_struct = json.load(f)
|
||||||
|
for uuid in app_struct['watching']:
|
||||||
|
if app_struct['watching'][uuid]['method'] == 'PATCH':
|
||||||
|
watches_with_method += 1
|
||||||
|
|
||||||
|
# Should be only one with method set to PATCH
|
||||||
|
assert watches_with_method == 1
|
||||||
|
|
Loading…
Reference in new issue