Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Mock figure8 and aws functions for testing (#104)
* first attempt at main function * updated requirements-test * fix namespace error * more testing for figure8 functions * testing for aws upload * pep8 * pep8 * switched to mocker * patch specific calls rather than entire function * Update requirements-test.txt Co-authored-by: willgraf <7930703+willgraf@users.noreply.github.com> * error handling for aws functions * assert statements for remaining functions * pep8 * removed print statements, added TODO for spy Co-authored-by: willgraf <7930703+willgraf@users.noreply.github.com>
- Loading branch information
1 parent
64c120d
commit b22e4ab
Showing
5 changed files
with
277 additions
and
56 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
# Copyright 2016-2020 The Van Valen Lab at the California Institute of | ||
# Technology (Caltech), with support from the Paul Allen Family Foundation, | ||
# Google, & National Institutes of Health (NIH) under Grant U24CA224309-01. | ||
# All rights reserved. | ||
# | ||
# Licensed under a modified Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.github.com/vanvalenlab/caliban-toolbox/LICENSE | ||
# | ||
# The Work provided may be used for non-commercial academic purposes only. | ||
# For any other use of the Work, including commercial use, please contact: | ||
# vanvalenlab@gmail.com | ||
# | ||
# Neither the name of Caltech nor the names of its contributors may be used | ||
# to endorse or promote products derived from this software without specific | ||
# prior written permission. | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
# ============================================================================== | ||
import os | ||
import boto3 | ||
import botocore | ||
import pytest | ||
|
||
from caliban_toolbox import aws_functions | ||
import pathlib | ||
|
||
|
||
class FakeS3(object): | ||
|
||
def __init__(self, aws_access_key_id='key', aws_secret_access_key='secret', raise_error=None): | ||
self.raise_error = raise_error | ||
|
||
def client(self, *_, **__): | ||
return self | ||
|
||
def upload_file(self, Filename, Bucket, Key, Callback, ExtraArgs): | ||
assert os.path.exists(Filename) | ||
|
||
def download_file(self, Bucket, Key, Filename): | ||
if self.raise_error is None: | ||
pathlib.Path(Filename).touch() | ||
elif self.raise_error is 'missing': | ||
raise botocore.exceptions.ClientError(error_response={'Error': {'Code': '404'}}, | ||
operation_name='missing_file') | ||
elif self.raise_error is 'other': | ||
raise botocore.exceptions.ClientError(error_response={'Error': {'Code': '555'}}, | ||
operation_name='some_other_error') | ||
|
||
|
||
# TODO: Can we spy on this function in order to have some sort of correctness test here? | ||
def test_aws_upload_files(mocker, tmp_path): | ||
mocker.patch('getpass.getpass', lambda *x: None) | ||
mocker.patch('boto3.Session', FakeS3) | ||
|
||
local_files = ['npz_file_' + str(num) for num in range(5)] | ||
aws_paths = ['aws_bucket/folder/npz_file_' + str(num) for num in range(5)] | ||
|
||
for file in local_files: | ||
pathlib.Path(os.path.join(tmp_path, file)).touch() | ||
|
||
local_paths = [os.path.join(tmp_path, file) for file in local_files] | ||
|
||
aws_functions.aws_upload_files(local_paths=local_paths, aws_paths=aws_paths) | ||
|
||
|
||
def test_aws_download_files(mocker, tmp_path): | ||
mocker.patch('getpass.getpass', lambda *x: None) | ||
mocker.patch('boto3.Session', FakeS3) | ||
|
||
filenames = ['npz_file_' + str(num) for num in range(5)] | ||
|
||
upload_log = {'stage': ['stage_0'], | ||
'aws_folder': ['temp_folder'], | ||
'filename': filenames} | ||
|
||
# no missing files | ||
missing = aws_functions.aws_download_files(upload_log=upload_log, output_dir=tmp_path) | ||
assert missing == [] | ||
|
||
# catch missing file error, return list of missing files | ||
mocker.patch('boto3.Session', | ||
lambda aws_access_key_id, aws_secret_access_key: FakeS3(raise_error='missing')) | ||
missing = aws_functions.aws_download_files(upload_log=upload_log, output_dir=tmp_path) | ||
missing = [os.path.split(file_path)[1] for file_path in missing] | ||
assert missing == filenames | ||
|
||
# all other errors not caught | ||
with pytest.raises(botocore.exceptions.ClientError): | ||
mocker.patch('boto3.Session', | ||
lambda aws_access_key_id, aws_secret_access_key: FakeS3(raise_error='other')) | ||
missing = aws_functions.aws_download_files(upload_log=upload_log, output_dir=tmp_path) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.