def test_get_extra_rows_when_type_is_repeated_per_row(self):
        data = {
            u"Number-1-response": [u"0,181", u"2"],
            u"MultiChoice-MAX_NUM_FORMS": [u"6"],
            u"redirect_url": [u""],
            u"save_draft": [u""],
            u"Number-6-response": [u"2,181", u"7"],
            u"Number-INITIAL_FORMS": [u"3"],
            u"Number-0-response": [u"0,181", u"1"],
            u"MultiChoice-0-response": [u"0,181", u"96"],
            u"MultiChoice-1-response": [u"0,181", u"115"],
            u"Number-5-response": [u"1,181", u"6"],
            u"Number-MAX_NUM_FORMS": [u"9"],
            u"MultiChoice-4-response": [u"2,181", u"99"],
            u"MultiChoice-TOTAL_FORMS": [u"6"],
            u"Number-3-response": [u"1,181", u"4"],
            u"Number-TOTAL_FORMS": [u"9"],
            u"MultiChoice-3-response": [u"1,181", u"116"],
            u"Number-2-response": [u"0,181", u"3"],
            u"MultiChoice-5-response": [u"2,181", u"117"],
            u"Number-7-response": [u"2,181", u"8"],
            u"Number-8-response": [u"2,181", u"9"],
            u"csrfmiddlewaretoken": [u"tx2R4QCrpl8IuHfaagFauUtC6XDs3u9C"],
            u"MultiChoice-2-response": [u"1,181", u"98"],
            u"MultiChoice-INITIAL_FORMS": [u"2"],
            u"Number-4-response": [u"1,181", u"5"],
        }

        data = clean_data_dict(dict(data))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Number", group_id=181))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "MultiChoice", group_id=181))
    def test_get_number_of_extra_rows_supplied_for_an_answer_type(self):
        data = {u'MultiChoice-MAX_NUM_FORMS': u'3', u'MultiChoice-TOTAL_FORMS': u'3',
                u'MultiChoice-INITIAL_FORMS': u'3', u'MultiChoice-0-response': ['0,1', 1],
                u'MultiChoice-1-response': ['1,1', 2, ], u'MultiChoice-2-response': ['2,1', 3, ],
                u'MultipleResponse-MAX_NUM_FORMS': u'3', u'MultipleResponse-TOTAL_FORMS': u'3',
                u'MultipleResponse-INITIAL_FORMS': u'3', u'MultipleResponse-0-response': ['0,1', '1', '2'],
                u'MultipleResponse-1-response': ['1,1', '6', '7'], u'MultipleResponse-2-response': ['2,1', '3', '4'],
                u'Number-MAX_NUM_FORMS': u'3', u'Number-TOTAL_FORMS': u'3',
                u'Number-INITIAL_FORMS': u'3', u'Number-0-response': ['0,1', '22', ],
                u'Number-1-response': ['1,1', '44', ], u'Number-2-response': ['2,1', '33', ],
                u'Text-MAX_NUM_FORMS': u'3', u'Text-TOTAL_FORMS': u'3',
                u'Text-INITIAL_FORMS': u'3', u'Text-0-response': ['0,1', 'Haha', ],
                u'Text-1-response': ['1,1', 'Hehe', ], u'Text-2-response': ['2,1', 'hehehe', ],
                u'Date-MAX_NUM_FORMS': u'3', u'Date-TOTAL_FORMS': u'3',
                u'Date-INITIAL_FORMS': u'3', u'Date-0-response': ['0,1', '2014-2-2', ],
                u'Date-1-response': ['1,1', '2014-2-2', ], u'Date-2-response': ['2,1', '2014-2-2', ]
        }

        data = clean_data_dict(dict(data))

        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Number', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'MultiChoice', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Date', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Text', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'MultipleResponse', 1))
    def test_get_number_of_extra_rows_supplied_for_an_answer_type(self):
        data = {
            u"MultiChoice-MAX_NUM_FORMS": u"3",
            u"MultiChoice-TOTAL_FORMS": u"3",
            u"MultiChoice-INITIAL_FORMS": u"3",
            u"MultiChoice-0-response": ["0,1", 1],
            u"MultiChoice-1-response": ["1,1", 2],
            u"MultiChoice-2-response": ["2,1", 3],
            u"Number-MAX_NUM_FORMS": u"3",
            u"Number-TOTAL_FORMS": u"3",
            u"Number-INITIAL_FORMS": u"3",
            u"Number-0-response": ["0,1", "22"],
            u"Number-1-response": ["1,1", "44"],
            u"Number-2-response": ["2,1", "33"],
            u"Text-MAX_NUM_FORMS": u"3",
            u"Text-TOTAL_FORMS": u"3",
            u"Text-INITIAL_FORMS": u"3",
            u"Text-0-response": ["0,1", "Haha"],
            u"Text-1-response": ["1,1", "Hehe"],
            u"Text-2-response": ["2,1", "hehehe"],
            u"Date-MAX_NUM_FORMS": u"3",
            u"Date-TOTAL_FORMS": u"3",
            u"Date-INITIAL_FORMS": u"3",
            u"Date-0-response": ["0,1", "2014-2-2"],
            u"Date-1-response": ["1,1", "2014-2-2"],
            u"Date-2-response": ["2,1", "2014-2-2"],
        }

        data = clean_data_dict(dict(data))

        self.assertEqual(["0", "1", "2"], extra_rows(data, "Number", 1))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "MultiChoice", 1))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Date", 1))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Text", 1))
    def test_get_number_of_extra_rows_supplied_for_an_answer_type_when_there_are_more_than_one_grid_of_the_same_type(
            self):
        data = {u'MultiChoice-MAX_NUM_FORMS': u'6', u'MultiChoice-TOTAL_FORMS': u'6',
                u'MultiChoice-INITIAL_FORMS': u'6', u'MultiChoice-0-response': ['0,1', 1, ],
                u'MultiChoice-1-response': ['1,1', 2, ], u'MultiChoice-2-response': ['2,1', 3, ],
                u'MultiChoice-3-response': ['0,2', 5, ],
                u'MultiChoice-4-response': ['1,2', 6, ], u'MultiChoice-5-response': [2],
                u'MultipleResponse-MAX_NUM_FORMS': u'6', u'MultipleResponse-TOTAL_FORMS': u'6',
                u'MultipleResponse-INITIAL_FORMS': u'6', u'MultipleResponse-0-response': ['0,1', '1', '2'],
                u'MultipleResponse-1-response': ['1,1', '6', '7'], u'MultipleResponse-2-response': ['1,2', '6', '7'],
                u'MultipleResponse-3-response': ['0,2', '3', '4'], u'MultipleResponse-4-response': ['1,2', '3', '4'],
                u'MultipleResponse-5-response': ['32', '41'],
                u'Number-MAX_NUM_FORMS': u'3', u'Number-TOTAL_FORMS': u'3',
                u'Number-INITIAL_FORMS': u'3', u'Number-0-response': ['0,1', '22', ],
                u'Number-1-response': ['1,1', '44', ], u'Number-2-response': ['2,1', '33', ],
                u'Text-MAX_NUM_FORMS': u'6', u'Text-TOTAL_FORMS': u'6',
                u'Text-INITIAL_FORMS': u'6', u'Text-0-response': ['0,1', 'Haha', ],
                u'Text-1-response': ['1,1', 'Hehe', ], u'Text-2-response': ['2,1', 'hehehe', ],
                u'Text-3-response': ['0,2', 'Hehe1', ], u'Text-4-response': ['1,2', 'Hehe', ],
                u'Text-5-response': ['hehe2'],
                u'Date-MAX_NUM_FORMS': u'3', u'Date-TOTAL_FORMS': u'3',
                u'Date-INITIAL_FORMS': u'3', u'Date-0-response': ['0,1', '2014-2-2', ],
                u'Date-1-response': ['1,1', '2014-2-2', ], u'Date-2-response': ['2,1', '2014-2-2', ],
        }

        data = clean_data_dict(dict(data))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Number', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'MultiChoice', 1))
        self.assertEqual(['0', '1'], extra_rows(data, 'MultiChoice', 2))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Date', 1))
        self.assertEqual(['0', '1', '2'], extra_rows(data, 'Text', 1))
        self.assertEqual(['0', '1'], extra_rows(data, 'Text', 2))
        self.assertEqual(['0', '1'], extra_rows(data, 'MultipleResponse', 1))
        self.assertEqual(['0', '1'], extra_rows(data, 'MultipleResponse', 2))
    def test_gets_primary_answer_per_row_given_rows(self):
        data = {
            u'MultiChoice-MAX_NUM_FORMS': u'4', u'MultiChoice-TOTAL_FORMS': u'4', u'MultiChoice-INITIAL_FORMS': u'4',
            u'MultiChoice-0-response': ['0,1', 'option1'],
            u'MultiChoice-1-response': ['1,1', 'option2'],
            u'MultiChoice-2-response': ['2,1', 'option3'],
            u'MultiChoice-3-response': [4],
            u'Number-MAX_NUM_FORMS': u'3', u'Number-TOTAL_FORMS': u'3', u'Number-INITIAL_FORMS': u'3',
            u'Number-0-response': ['0,1', '22'],
            u'Number-1-response': ['1,1', '44'],
            u'Number-2-response': ['2,1', '33'],
            u'Text-MAX_NUM_FORMS': u'4', u'Text-TOTAL_FORMS': u'4', u'Text-INITIAL_FORMS': u'4',
            u'Text-0-response': ['0,1', 'row-0-column-0'],
            u'Text-1-response': ['0,1', 'row-0-column-1'],
            u'Text-2-response': ['1,1', 'row-1-column-0'],
            u'Text-3-response': ['1,1', 'row1-column-1'],
            u'Text-4-response': ['2,1', 'row-2-column-0'],
            u'Text-5-response': ['2,1', 'row2-column-1'],
            u'Date-MAX_NUM_FORMS': u'3', u'Date-TOTAL_FORMS': u'3', u'Date-INITIAL_FORMS': u'3',
            u'Date-0-response': ['0,1', '2014-2-21'],
            u'Date-1-response': ['1,1', '2014-2-22'],
            u'Date-2-response': ['2,1', '2014-2-23'],
        }

        data = clean_data_dict(dict(data))
        rows = extra_rows(data, "Number", group_id=1)
        self.assertEqual(['row-0-column-0', 'row-1-column-0', 'row-2-column-0'],
                         primary_answers(data, rows, 'Text', group_id=1))
    def test_get_extra_rows_when_type_is_repeated_per_row(self):
        data = {u'Number-1-response': [u'0,181', u'2', ], u'MultiChoice-MAX_NUM_FORMS': [u'6'], u'redirect_url': [u''],
                u'save_draft': [u''], u'Number-6-response': [u'2,181', u'7', ], u'Number-INITIAL_FORMS': [u'3'],
                u'Number-0-response': [u'0,181', u'1', ], u'MultiChoice-0-response': [u'0,181', u'96', ],
                u'MultiChoice-1-response': [u'0,181', u'115', ], u'Number-5-response': [u'1,181', u'6', ],
                u'Number-MAX_NUM_FORMS': [u'9'], u'MultiChoice-4-response': [u'2,181', u'99', ],
                u'MultiChoice-TOTAL_FORMS': [u'6'], u'Number-3-response': [u'1,181', u'4', ],
                u'Number-TOTAL_FORMS': [u'9'], u'MultiChoice-3-response': [u'1,181', u'116', ],
                u'Number-2-response': [u'0,181', u'3', ], u'MultiChoice-5-response': [u'2,181', u'117', ],
                u'Number-7-response': [u'2,181', u'8', ], u'Number-8-response': [u'2,181', u'9', ],
                u'csrfmiddlewaretoken': [u'tx2R4QCrpl8IuHfaagFauUtC6XDs3u9C'],
                u'MultiChoice-2-response': [u'1,181', u'98', ], u'MultiChoice-INITIAL_FORMS': [u'2'],
                u'Number-4-response': [u'1,181', u'5', ]}

        data = clean_data_dict(dict(data))
        self.assertEqual(['0', '1', '2'], extra_rows(data, "Number", group_id=181))
        self.assertEqual(['0', '1', '2'], extra_rows(data, "MultiChoice", group_id=181))
 def get_extra_rows(self, answer_type, group):
     primary_question = group.primary_question()
     saved_primary_answers = primary_question.answered_options(questionnaire=self.questionnaire, country=self.country,
                                                 question_group=group, version=self.version)
     if self.cleaned_data:
         rows = extra_rows(self.cleaned_data, answer_type, group.id)
         posted_primary_answers = primary_answers(self.cleaned_data, rows, primary_question.answer_type, group.id)
         saved_primary_answers.extend(posted_primary_answers[len(saved_primary_answers):])
     return saved_primary_answers or EMPTY_ROW
 def assign_answer_groups(self):
     current_answer_form_counter = self.ANSWER_FORM_COUNTER
     self.ANSWER_FORM_COUNTER = self._initialize_form_counter()
     for subsection in self.section.sub_sections.all():
         for group in subsection.parent_question_groups():
             for order in group.question_orders():
                 if group.grid and group.display_all:
                     if order.question.is_primary:
                         for option in order.question.options.all():
                             answer_group = self._add_answer_to_group(order)
                             self._assign_non_primary_answers_to(answer_group, question_group=group)
                 elif group.grid and group.allow_multiples:
                     if order.question.is_primary:
                         for option in extra_rows(self.cleaned_data, order.question.answer_type, group.id):
                             answer_group = self._add_answer_to_group(order)
                             self._assign_non_primary_answers_to(answer_group, question_group=group)
                 else:
                     self._add_answer_to_group(order)
     self.ANSWER_FORM_COUNTER = current_answer_form_counter
    def test_gets_primary_answer_per_row_given_rows(self):
        data = {
            u"MultiChoice-MAX_NUM_FORMS": u"4",
            u"MultiChoice-TOTAL_FORMS": u"4",
            u"MultiChoice-INITIAL_FORMS": u"4",
            u"MultiChoice-0-response": ["0,1", "option1"],
            u"MultiChoice-1-response": ["1,1", "option2"],
            u"MultiChoice-2-response": ["2,1", "option3"],
            u"MultiChoice-3-response": [4],
            u"Number-MAX_NUM_FORMS": u"3",
            u"Number-TOTAL_FORMS": u"3",
            u"Number-INITIAL_FORMS": u"3",
            u"Number-0-response": ["0,1", "22"],
            u"Number-1-response": ["1,1", "44"],
            u"Number-2-response": ["2,1", "33"],
            u"Text-MAX_NUM_FORMS": u"4",
            u"Text-TOTAL_FORMS": u"4",
            u"Text-INITIAL_FORMS": u"4",
            u"Text-0-response": ["0,1", "row-0-column-0"],
            u"Text-1-response": ["0,1", "row-0-column-1"],
            u"Text-2-response": ["1,1", "row-1-column-0"],
            u"Text-3-response": ["1,1", "row1-column-1"],
            u"Text-4-response": ["2,1", "row-2-column-0"],
            u"Text-5-response": ["2,1", "row2-column-1"],
            u"Date-MAX_NUM_FORMS": u"3",
            u"Date-TOTAL_FORMS": u"3",
            u"Date-INITIAL_FORMS": u"3",
            u"Date-0-response": ["0,1", "2014-2-21"],
            u"Date-1-response": ["1,1", "2014-2-22"],
            u"Date-2-response": ["2,1", "2014-2-23"],
        }

        data = clean_data_dict(dict(data))
        rows = extra_rows(data, "Number", group_id=1)
        self.assertEqual(
            ["row-0-column-0", "row-1-column-0", "row-2-column-0"], primary_answers(data, rows, "Text", group_id=1)
        )
    def test_get_number_of_extra_rows_supplied_for_an_answer_type_when_there_are_more_than_one_grid_of_the_same_type(
        self
    ):
        data = {
            u"MultiChoice-MAX_NUM_FORMS": u"6",
            u"MultiChoice-TOTAL_FORMS": u"6",
            u"MultiChoice-INITIAL_FORMS": u"6",
            u"MultiChoice-0-response": ["0,1", 1],
            u"MultiChoice-1-response": ["1,1", 2],
            u"MultiChoice-2-response": ["2,1", 3],
            u"MultiChoice-3-response": ["0,2", 5],
            u"MultiChoice-4-response": ["1,2", 6],
            u"MultiChoice-5-response": [2],
            u"Number-MAX_NUM_FORMS": u"3",
            u"Number-TOTAL_FORMS": u"3",
            u"Number-INITIAL_FORMS": u"3",
            u"Number-0-response": ["0,1", "22"],
            u"Number-1-response": ["1,1", "44"],
            u"Number-2-response": ["2,1", "33"],
            u"Text-MAX_NUM_FORMS": u"6",
            u"Text-TOTAL_FORMS": u"6",
            u"Text-INITIAL_FORMS": u"6",
            u"Text-0-response": ["0,1", "Haha"],
            u"Text-1-response": ["1,1", "Hehe"],
            u"Text-2-response": ["2,1", "hehehe"],
            u"Text-3-response": ["0,2", "Hehe1"],
            u"Text-4-response": ["1,2", "Hehe"],
            u"Text-5-response": ["hehe2"],
            u"Date-MAX_NUM_FORMS": u"3",
            u"Date-TOTAL_FORMS": u"3",
            u"Date-INITIAL_FORMS": u"3",
            u"Date-0-response": ["0,1", "2014-2-2"],
            u"Date-1-response": ["1,1", "2014-2-2"],
            u"Date-2-response": ["2,1", "2014-2-2"],
        }

        data = clean_data_dict(dict(data))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Number", 1))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "MultiChoice", 1))
        self.assertEqual(["0", "1"], extra_rows(data, "MultiChoice", 2))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Date", 1))
        self.assertEqual(["0", "1", "2"], extra_rows(data, "Text", 1))
        self.assertEqual(["0", "1"], extra_rows(data, "Text", 2))