mangroveorg/datawinners

View on GitHub
datawinners/test_utils.py

Summary

Maintainability
F
1 wk
Test Coverage
# vim: ai ts=4 sts=4 et sw=4 encoding=utf-8
import unittest
import datetime
from django.test import TestCase
from django.test.client import RequestFactory
from datawinners import workbook_utils
from datawinners.workbook_utils import get_excel_sheet, write_row_to_worksheet
from mangrove.datastore.database import DatabaseManager
from mangrove.datastore.settings import COUCHDB_CREDENTIALS
from mock import Mock, call, PropertyMock, patch
from xlwt import Worksheet, Column
from datawinners.accountmanagement.models import Organization
from datawinners.settings import COUCH_DB_SERVER
from datawinners.tests.data import DEFAULT_TEST_ORG_ID, DEFAULT_TEST_ORG_NAME, RAW_DATA, HEADER_LIST, DEFAULT_TEST_ORG_TEL_NO
from entity.views import add_codes_sheet
from mangrove.form_model.field import ExcelDate
import utils

class TestUtils(TestCase):

    fixtures = ['test_data.json']

    def test_should_generate_excel_sheet(self):
        raw_data = RAW_DATA
        header_list = HEADER_LIST
        raw_data.insert(0, header_list)
        sheet_name = 'test'
        wb = get_excel_sheet(raw_data, sheet_name)
        self.assertEquals(3, len(wb.get_sheet(0).rows))
        self.assertEquals(3, wb.get_sheet(0).row(0).get_cells_count())

    def test_should_write_date_value_to_excel_sheet(self):
        raw_data = RAW_DATA
        wb = get_excel_sheet(raw_data, "test")
        self.assertEquals(3, len(wb.get_sheet(0).rows))
        self.assertEquals(3, wb.get_sheet(0).row(0).get_cells_count())

    def test_should_add_codes_sheet_to_excel(self):
        raw_data = RAW_DATA
        wb = get_excel_sheet(raw_data, "test")
        add_codes_sheet(wb, "form_code", ('q1', 'q2', 'q3'))
        code_sheet = wb.get_sheet(1)
        self.assertEquals(1, len(code_sheet.rows))
        self.assertEquals(4, code_sheet.row(0).get_cells_count())

    def test_should_return_organization(self):
        org_id = DEFAULT_TEST_ORG_ID
        request = self._get_request_mock(org_id)

        organization = utils.get_organization(request)
        self.assertEquals(org_id, organization.org_id)

    def test_convert_to_ordinal(self):
        self.assertEquals('12th', utils.convert_to_ordinal(12))
        self.assertEquals('21st', utils.convert_to_ordinal(21))
        self.assertEquals('32nd', utils.convert_to_ordinal(32))
        self.assertEquals('43rd', utils.convert_to_ordinal(43))
        self.assertEquals('77th', utils.convert_to_ordinal(77))

    def test_generate_document_store(self):
        self.assertEquals(u'hni_testorg_slx364903',
            utils.generate_document_store_name(DEFAULT_TEST_ORG_NAME, DEFAULT_TEST_ORG_ID))

    def test_should_return_organization_setting(self):
        request = self._get_request_mock(DEFAULT_TEST_ORG_ID)
        org_setting = utils.get_organization_settings_from_request(request)
        self.assertEquals(DEFAULT_TEST_ORG_TEL_NO, org_setting.sms_tel_number)

    def test_should_return_database_manager(self):
        with patch('datawinners.main.database.mangrove_db_manager') as mangrove_db_manager_mock:
            mangrove_db_manager_mock.side_effect = lambda server, database, credentials: Mock(spec=DatabaseManager, database_name = database)
            organization = Organization.objects.get(pk=DEFAULT_TEST_ORG_ID)
            dbm = utils.get_database_manager_for_org(organization)
            self.assertEquals(utils.generate_document_store_name(DEFAULT_TEST_ORG_NAME, DEFAULT_TEST_ORG_ID), dbm.database_name)
            mangrove_db_manager_mock.assert_called_once_with(credentials=COUCHDB_CREDENTIALS, database=u'hni_testorg_slx364903', server=COUCH_DB_SERVER)

    def _get_request_mock(self, org_id):
        request = RequestFactory().get('/account/')
        request.user = Mock()
        mock_profile = Mock()
        mock_profile.org_id = Mock(return_value=org_id)
        request.user.get_profile = Mock(return_value=mock_profile)
        return request

    def test_should_return_ymd(self):
        result = utils.convert_dmy_to_ymd("06-07-2012")
        self.assertEquals(result, "2012-07-06")

    def test_project_name_generator(self):
        projects_name = ["test project", "untitled project", "untitled project - 1"]
        generated = utils.generate_project_name(projects_name)
        self.assertEqual("Untitled Project - 2", unicode(generated))

    def test_should_find_changed_questions(self):
        old_questionnaire = [dict({'label': 'question1', 'name': 'quest1', 'type': 'text'}),
                             dict({'label': 'old question1', 'name': 'old1', 'type': 'int'}),
        ]

        self.old_questionnaire = [type('Field', (object, ), question) for question in old_questionnaire]

        new_questionnaire = [dict({'label': 'new question1', 'name': 'quest1', 'type': 'text'}),
                             dict({'label': 'old question1', 'name': 'old1', 'type': 'int'}),
                             dict({'label': 'new question', 'name': 'quest2', 'type': 'text'})
        ]
        self.new_questionnaire = [type('Field', (object, ), question) for question in new_questionnaire]
        changed_questionnaire = utils.get_changed_questions(self.old_questionnaire, self.new_questionnaire,
            subject=False)
        self.assertEqual(changed_questionnaire["added"], ['new question'])
        self.assertEqual(changed_questionnaire["changed"], ['new question1'])

# The styles for same type of cells have to use the same Style Object. Creating new Styles object for each class will
# lead to errors as xlwt supports only 4096 types of styles
class TestExcelStyles(unittest.TestCase):
    def test_float_values_should_use_same_style(self):
        ws = Mock(spec=Worksheet)
        row = [12.3, 13.45]
        write_row_to_worksheet(ws, row, 1)
        ws.write.assert_any_call(1, 0, 12.3, style=workbook_utils.EXCEL_CELL_FLOAT_STYLE)
        ws.write.assert_any_call(1, 1, 13.45, style=workbook_utils.EXCEL_CELL_FLOAT_STYLE)


    def test_float_values_that_can_be_represented_as_integer_should_use_same_style(self):
        ws = Mock(spec=Worksheet)
        row = [12.0, 13.0]
        write_row_to_worksheet(ws, row, 1)
        ws.write.assert_any_call(1, 0, 12, style=workbook_utils.EXCEL_CELL_INTEGER_STYLE)
        ws.write.assert_any_call(1, 1, 13, style=workbook_utils.EXCEL_CELL_INTEGER_STYLE)


    def test_data_values_should_use_same_style_for_mm_yyyy_format(self):
        ws = Mock(spec=Worksheet)
        date_1 = ExcelDate(datetime.datetime(2012, 04, 24), 'mm.yyyy')
        date_2 = ExcelDate(datetime.datetime(2012, 05, 24), 'mm.yyyy')
        row = [date_1, date_2]
        width = workbook_utils.WIDTH_ONE_CHAR * (len(str(date_1.date)) + workbook_utils.BUFFER_WIDTH)
        mock_width = PropertyMock(return_value=width)
        mock_column = Mock(spec=Column)
        ws.col.return_value = mock_column
        type(mock_column).width = mock_width

        write_row_to_worksheet(ws, row, 1)

        mock_width.assert_called_with(width)
        ws.write.assert_any_call(1, 0, date_1.date, style=workbook_utils.EXCEL_DATE_STYLE.get('mm.yyyy'))
        ws.write.assert_any_call(1, 1, date_2.date, style=workbook_utils.EXCEL_DATE_STYLE.get('mm.yyyy'))
        ws.col.assert_any_with(0)
        ws.col.assert_any_with(1)

    def test_data_values_should_use_same_style_for_dd_mm_yyyy_format(self):
        ws = Mock(spec=Worksheet)
        date_1 = ExcelDate(datetime.datetime(2012, 04, 12), 'dd.mm.yyyy')
        date_2 = ExcelDate(datetime.datetime(2012, 05, 29), 'dd.mm.yyyy')
        row = [date_1, date_2]
        width = workbook_utils.WIDTH_ONE_CHAR * (len(str(date_1.date)) + workbook_utils.BUFFER_WIDTH)
        mock_width_property = PropertyMock(return_value=width)
        mock_column = Mock(spec=Column)
        ws.col.return_value = mock_column
        type(mock_column).width = mock_width_property

        write_row_to_worksheet(ws, row, 1)

        mock_width_property.assert_called_with(width)
        ws.write.assert_any_call(1, 0, date_1.date, style=workbook_utils.EXCEL_DATE_STYLE.get('dd.mm.yyyy'))
        ws.write.assert_any_call(1, 1, date_2.date, style=workbook_utils.EXCEL_DATE_STYLE.get('dd.mm.yyyy'))
        ws.col.assert_any_with(0)
        ws.col.assert_any_with(1)

    def test_data_values_should_use_same_style_for_mm_dd_yyyy_format(self):
        ws = Mock(spec=Worksheet)
        date_1 = ExcelDate(datetime.datetime(2012, 04, 12), 'mm.dd.yyyy')
        date_2 = ExcelDate(datetime.datetime(2012, 05, 29), 'mm.dd.yyyy')
        row = [date_1, date_2]
        width = workbook_utils.WIDTH_ONE_CHAR * (len(str(date_1.date)) + workbook_utils.BUFFER_WIDTH)
        mock_width_property = PropertyMock(return_value=width)
        mock_column = Mock(spec=Column)
        ws.col.return_value = mock_column
        type(mock_column).width = mock_width_property

        write_row_to_worksheet(ws, row, 1)

        mock_width_property.assert_called_with(width)
        ws.write.assert_any_call(1, 0, date_1.date, style=workbook_utils.EXCEL_DATE_STYLE.get('mm.dd.yyyy'))
        ws.write.assert_any_call(1, 1, date_2.date, style=workbook_utils.EXCEL_DATE_STYLE.get('mm.dd.yyyy'))
        ws.col.assert_any_with(0)
        ws.col.assert_any_with(1)

    def test_data_values_should_use_same_style_for_submission_dates(self):
        ws = Mock(spec=Worksheet)
        date_1 = ExcelDate(datetime.datetime(2012, 04, 12, 13, 56, 40), 'submission_date')
        date_2 = ExcelDate(datetime.datetime(2012, 05, 29, 13, 56, 40), 'submission_date')
        row = [date_1, date_2]
        width = workbook_utils.WIDTH_ONE_CHAR * (len(str(date_1.date)) + workbook_utils.BUFFER_WIDTH)
        mock_width_property = PropertyMock(return_value=width)
        mock_column = Mock(spec=Column)
        ws.col.return_value = mock_column
        type(mock_column).width = mock_width_property

        write_row_to_worksheet(ws, row, 1)

        mock_width_property.assert_called_with(width)
        ws.write.assert_any_call(1, 0, date_1.date, style=workbook_utils.EXCEL_DATE_STYLE.get('submission_date'))
        ws.write.assert_any_call(1, 1, date_2.date, style=workbook_utils.EXCEL_DATE_STYLE.get('submission_date'))
        ws.col.assert_any_with(0)
        ws.col.assert_any_with(1)