Skip to content

Commit

Permalink
FTP upload integration tests.
Browse files Browse the repository at this point in the history
Test various configuration options (ftp_upload_dir, ftp_upload_identifier, ftp_upload_dir_template) and various upload API parameters (space_to_tab, to_posix_lines, auto_decompress).
  • Loading branch information
jmchilton committed Oct 4, 2017
1 parent 8eac80a commit 108e94c
Show file tree
Hide file tree
Showing 6 changed files with 287 additions and 28 deletions.
10 changes: 5 additions & 5 deletions test/api/test_tools_upload.py
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
from base import api

from base.constants import (
ONE_TO_SIX_ON_WINDOWS,
ONE_TO_SIX_WITH_SPACES,
ONE_TO_SIX_WITH_TABS,
)
from base.populators import (
DatasetPopulator,
skip_without_datatype,
)

from galaxy.tools.verify.test_data import TestDataResolver

ONE_TO_SIX_WITH_SPACES = "1 2 3\n4 5 6\n"
ONE_TO_SIX_WITH_TABS = "1\t2\t3\n4\t5\t6\n"
ONE_TO_SIX_ON_WINDOWS = "1\t2\t3\r4\t5\t6\r"


class ToolsUploadTestCase(api.ApiTestCase):

Expand Down
14 changes: 8 additions & 6 deletions test/base/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,16 @@
assert_not_has_keys,
assert_status_code_is,
)
from .api_util import get_master_api_key, get_user_api_key
from .api_util import (
ADMIN_TEST_USER,
get_master_api_key,
get_user_api_key,
OTHER_USER,
TEST_USER,
)
from .interactor import GalaxyInteractorApi as BaseInteractor
from .testcase import FunctionalTestCase

TEST_USER = "[email protected]"
ADMIN_TEST_USER = "[email protected]"
DEFAULT_OTHER_USER = "[email protected]" # A second user for API testing.


class UsesApiTestCaseMixin:

Expand Down Expand Up @@ -48,7 +50,7 @@ def _setup_user_get_key(self, email):
return self._post("users/%s/api_key" % user["id"], admin=True).json()

@contextmanager
def _different_user(self, email=DEFAULT_OTHER_USER):
def _different_user(self, email=OTHER_USER):
""" Use in test cases to switch get/post operations to act as new user,
with self._different_user( "[email protected]" ):
Expand Down
8 changes: 8 additions & 0 deletions test/base/api_util.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,14 @@
DEFAULT_GALAXY_MASTER_API_KEY = "TEST123"
DEFAULT_GALAXY_USER_API_KEY = None

DEFAULT_TEST_USER = "[email protected]"
DEFAULT_ADMIN_TEST_USER = "[email protected]"
DEFAULT_OTHER_USER = "[email protected]" # A second user for API testing.

TEST_USER = os.environ.get("GALAXY_TEST_USER_EMAIL", DEFAULT_TEST_USER)
ADMIN_TEST_USER = os.environ.get("GALAXY_TEST_ADMIN_USER_EMAIL", DEFAULT_ADMIN_TEST_USER)
OTHER_USER = os.environ.get("GALAXY_TEST_OTHER_USER_EMAIL", DEFAULT_OTHER_USER)


def get_master_api_key():
""" Test master API key to use for functional test. This key should be
Expand Down
6 changes: 6 additions & 0 deletions test/base/constants.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
"""Just constants useful for testing across test types."""

# Following constants used by upload tests.
ONE_TO_SIX_WITH_SPACES = "1 2 3\n4 5 6\n"
ONE_TO_SIX_WITH_TABS = "1\t2\t3\n4\t5\t6\n"
ONE_TO_SIX_ON_WINDOWS = "1\t2\t3\r4\t5\t6\r"
17 changes: 12 additions & 5 deletions test/base/populators.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,12 +104,14 @@ class BaseDatasetPopulator(object):
Galaxy - implementations must implement _get and _post.
"""

def new_dataset(self, history_id, content='TestData123', wait=False, **kwds):
def new_dataset(self, history_id, content=None, wait=False, **kwds):
run_response = self.new_dataset_request(history_id, content=content, wait=wait, **kwds)
return run_response.json()["outputs"][0]

def new_dataset_request(self, history_id, content='TestData123', wait=False, **kwds):
payload = self.upload_payload(history_id, content, **kwds)
def new_dataset_request(self, history_id, content=None, wait=False, **kwds):
if content is None and "ftp_files" not in kwds:
content = "TestData123"
payload = self.upload_payload(history_id, content=content, **kwds)
run_response = self.tools_post(payload)
if wait:
self.wait_for_tool_run(history_id, run_response)
Expand Down Expand Up @@ -157,7 +159,7 @@ def new_history(self, **kwds):
history_id = create_history_response.json()["id"]
return history_id

def upload_payload(self, history_id, content, **kwds):
def upload_payload(self, history_id, content=None, **kwds):
name = kwds.get("name", "Test Dataset")
dbkey = kwds.get("dbkey", "?")
file_type = kwds.get("file_type", 'txt')
Expand All @@ -166,7 +168,9 @@ def upload_payload(self, history_id, content, **kwds):
'dbkey': dbkey,
'file_type': file_type,
}
if hasattr(content, 'read'):
if content is None:
upload_params["files_0|ftp_files"] = kwds.get("ftp_files")
elif hasattr(content, 'read'):
upload_params["files_0|file_data"] = content
else:
upload_params['files_0|url_paste'] = content
Expand All @@ -185,6 +189,9 @@ def upload_payload(self, history_id, content, **kwds):
upload_type='upload_dataset'
)

def get_remote_files(self, target="ftp"):
return self._get("remote_files", data={"target": target}).json()

def run_tool_payload(self, tool_id, inputs, history_id, **kwds):
if "files_0|file_data" in inputs:
kwds["__files"] = {"files_0|file_data": inputs["files_0|file_data"]}
Expand Down
Loading

0 comments on commit 108e94c

Please sign in to comment.