pacifica/pacifica-cartd

View on GitHub
tests/test/tasks_test.py

Summary

Maintainability
A
0 mins
Test Coverage
#!/usr/bin/python
# -*- coding: utf-8 -*-
"""File used to unit test the pacifica_cart tasks."""
import os
import datetime
import json
import mock
import requests
from cherrypy.test import helper
from pacifica.cartd.orm import Cart, File
from pacifica.cartd.tasks import stage_file_task, stage_files, status_file_task, pull_file
from pacifica.cartd.archive_requests import ArchiveRequests
from pacifica.cartd.utils import Cartutils
from pacifica.cartd.tasks import CART_APP
from ..cart_db_setup_test import TestCartdBase

CART_APP.conf.CELERY_ALWAYS_EAGER = True


class TestTasks(TestCartdBase, helper.CPWebCase):
    """Contains tests for tasks that dont need all services stood up."""

    @mock.patch.object(ArchiveRequests, 'stage_file')
    def test_bad_stage(self, mock_stage_file):
        """Test the bad stage of a archive file."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_stage_file.side_effect = requests.exceptions.RequestException(
            mock.Mock(status=500),
            'Error'
        )
        file_id = test_file.id
        stage_file_task(file_id)
        cart_file = File.get(File.id == file_id)
        status = cart_file.status
        self.assertEqual(status, 'error')

    @mock.patch.object(ArchiveRequests, 'status_file')
    @mock.patch.object(ArchiveRequests, 'stage_file')
    def test_bad_status(self, mock_stage_file, mock_status_file):
        """Test the bad status of a archive file."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_stage_file.return_value = True
        mock_status_file.side_effect = requests.exceptions.RequestException(
            mock.Mock(status=500),
            'Error'
        )
        file_id = test_file.id
        status_file_task(file_id)
        cart_file = File.get(File.id == file_id)
        status = cart_file.status
        self.assertEqual(status, 'error')

    @mock.patch.object(os, 'utime')
    @mock.patch.object(ArchiveRequests, 'pull_file')
    @mock.patch.object(ArchiveRequests, 'status_file')
    @mock.patch.object(ArchiveRequests, 'stage_file')
    def test_bad_pull(self, mock_stage_file, mock_status_file, mock_pull_file, mock_utime):
        """Test the bad pull of a archive file."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_stage_file.return_value = True
        mock_status_file.return_value = json.dumps({
            'bytes_per_level': '(10L, 0L)',
            'ctime': '1444629567',
            'file': '1.txt',
            'file_storage_media': 'disk',
            'filesize': '10',
            'message': 'File was found',
            'mtime': '1444937154'
        })
        mock_pull_file.side_effect = requests.exceptions.RequestException(
            mock.Mock(status=500),
            'Error'
        )
        mock_utime.return_value = True
        file_id = test_file.id
        stage_file_task(file_id)
        cart_file = File.get(File.id == file_id)
        status = cart_file.status
        self.assertEqual(status, 'error')

    @mock.patch.object(Cartutils, 'check_file_size_needed')
    @mock.patch.object(ArchiveRequests, 'status_file')
    @mock.patch.object(ArchiveRequests, 'stage_file')
    def test_bad_size_needed(self, mock_stage_file, mock_status_file, mock_check_file):
        """Test a error in check_file_size_needed."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_stage_file.return_value = True
        mock_status_file.return_value = json.dumps({
            'bytes_per_level': '(10L, 0L)',
            'ctime': '1444629567',
            'file': '1.txt',
            'file_storage_media': 'disk',
            'filesize': '10',
            'message': 'File was found',
            'mtime': '1444937154'
        })
        mock_check_file.return_value = -1
        file_id = test_file.id
        stage_file_task(file_id)
        cart_file = File.get(File.id == file_id)
        status = cart_file.status
        self.assertEqual(status, 'staging')

    @mock.patch.object(Cartutils, 'check_file_ready_pull')
    @mock.patch.object(ArchiveRequests, 'status_file')
    @mock.patch.object(ArchiveRequests, 'stage_file')
    def test_bad_ready_to_pull(self, mock_stage_file, mock_status_file, mock_check_file):
        """Test a error return from a file not ready to pull."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_stage_file.return_value = True
        mock_status_file.return_value = json.dumps({
            'bytes_per_level': '(10L, 0L)',
            'ctime': '1444629567',
            'file': '1.txt',
            'file_storage_media': 'disk',
            'filesize': '10',
            'message': 'File was found',
            'mtime': '1444937154'
        })
        mock_check_file.return_value = -1
        file_id = test_file.id
        stage_file_task(file_id)
        cart_file = File.get(File.id == file_id)
        status = cart_file.status
        self.assertEqual(status, 'staging')

    @mock.patch.object(Cartutils, 'update_cart_files')
    def test_bad_file_ids(self, mock_update):
        """Test a error return from a file not ready to pull."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_update.return_value = 'I am a error'
        file_id = test_file.id
        stage_files(file_id, test_cart.id)
        cart_after = Cart.get(Cart.id == test_cart.id)
        status = cart_after.status
        self.assertEqual(status, 'error')

    def test_stage_bad_file_id(self):
        """Test a error return from a file not ready to pull."""
        file_id = 9999999
        stage_file_task(file_id)
        self.assertEqual(True, True)

    def test_stage_cart_deleted(self):
        """Test a error return from a file not ready to pull."""
        test_cart = Cart.create(
            cart_uid='1',
            status='staging',
            deleted_date='2017-05-03 00:00:00'
        )
        test_file = File.create(
            cart=test_cart,
            file_name='1.txt',
            bundle_path=os.path.join(os.getenv('VOLUME_PATH'), '1', '1.txt')
        )
        file_id = test_file.id
        stage_file_task(file_id)
        self.assertEqual(True, True)

    def test_status_cart_deleted(self):
        """Test a error return from a file not ready to pull."""
        test_cart = Cart.create(
            cart_uid='1',
            status='staging',
            deleted_date='2017-05-03 00:00:00'
        )
        test_file = File.create(
            cart=test_cart,
            file_name='1.txt',
            bundle_path=os.path.join(os.getenv('VOLUME_PATH'), '1', '1.txt')
        )
        file_id = test_file.id
        status_file_task(file_id)
        self.assertEqual(True, True)

    @mock.patch.object(ArchiveRequests, 'pull_file')
    def test_bad_pull_value(self, mock_pull):
        """Test a error return from a file not ready to pull."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        mock_pull.side_effect = ValueError('Error with hash pulling file')
        file_id = test_file.id
        pull_file(file_id, os.path.join(os.getenv('VOLUME_PATH'), '1', '1.txt'), '9999999', False)
        cart_after = Cart.get(Cart.id == test_cart.id)
        status = cart_after.status
        self.assertEqual(status, 'error')

    @mock.patch.object(ArchiveRequests, 'pull_file')
    def test_bad_deleted_cart(self, mock_pull):
        """Test a error return from a file not ready to pull."""
        test_cart = self.create_sample_cart()
        test_file = self.create_sample_file(test_cart)
        test_cart.deleted_date = datetime.datetime.now()
        test_cart.save()
        pull_file(test_file.id, os.path.join(os.getenv('VOLUME_PATH'), '1', '1.txt'), '9999999', False)
        mock_pull.assert_not_called()