Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TDL-19801: Tap fetch data for sub-questions #62

2 changes: 1 addition & 1 deletion .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ jobs:
name: 'Unit Tests'
command: |
source /usr/local/share/virtualenvs/tap-tester/bin/activate
pip install nose coverage
pip install nose coverage parameterized
nosetests --with-coverage --cover-erase --cover-package=tap_typeform --cover-html-dir=htmlcov tests/unittests
coverage html
- store_test_results:
Expand Down
26 changes: 23 additions & 3 deletions tap_typeform/schemas/questions.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,27 @@
"ref": {
"type": ["null", "string"],
"selected": true
}
},
"key_properties": ["form_id","question_id"]
},
"sub_questions": {
"type": ["null", "array"],
"items": {
"type": ["null", "object"],
"properties": {
"question_id": {
"type": ["null", "string"],
"selected": true
},
"title": {
"type": ["null", "string"],
"selected": true
},
"ref": {
"type": ["null", "string"],
"selected": true
}
}
}
}
},
"key_properties": ["form_id","question_id"]
}
22 changes: 21 additions & 1 deletion tap_typeform/streams.py
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,19 @@ def get_landings(atx, form_id, bookmark):

yield from items

def fetch_sub_questions(row):
'''This function fetches records for each sub_question in a question group and returns a list of fetched sub_questions'''
sub_questions = [] #Creating blank list to accommodate each sub-question's records

#Appending each sub-question to the list
for question in row['properties'].get('fields',[]):
dbshah1212 marked this conversation as resolved.
Show resolved Hide resolved
sub_questions.append({
"question_id": question['id'],
"title": question['title'],
"ref": question['ref']
})

return sub_questions

def sync_form_definition(atx, form_id):
with singer.metrics.job_timer('form definition '+form_id):
Expand All @@ -156,12 +169,19 @@ def sync_form_definition(atx, form_id):
# we only care about a few fields in the form definition
# just those that give an analyst a reference to the submissions
for row in data:
sub_questions ={} #Creating a blank dictionary to store records of sub_questions,if any

#If type of question is group, i.e. it has sub_questions, then fetch those sub_questions
if row['type'] == 'group':
sub_questions['sub_questions'] = fetch_sub_questions(row)

#If sub_questions are fetched then add those in this field and display the same, else don't display this field
definition_data_rows.append({
"form_id": form_id,
"question_id": row['id'],
"title": row['title'],
"ref": row['ref']
})
}|sub_questions)

write_records(atx, 'questions', definition_data_rows)

Expand Down
13 changes: 11 additions & 2 deletions tests/test_typeform_bookmarks.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ def test_run(self):
##########################################################################
### First Sync
##########################################################################
self.start_date_1 = self.get_properties().get("start_date")
self.start_date_1 = "2022-07-20T00:00:00Z"
self.start_date_2 = self.timedelta_formatted(self.start_date_1, days=3)

self.start_date = self.start_date_1
Expand All @@ -107,7 +107,16 @@ def test_run(self):
##########################################################################

new_states = {'bookmarks': dict()}
simulated_states = self.calculated_states_by_stream(first_sync_bookmarks)
simulated_states = {
'forms': {'last_updated_at': '2022-07-22T16:00:47Z'},
'landings': {'mVn2wE55': '2022-07-21T10:32:15.000000Z',
'xJ8emTTy': '2022-07-24T15:49:54Z',
'cfyTOGxc': '2022-07-24T16:49:54Z'},
'answers': {'mVn2wE55': '2022-07-21T00:00:00Z',
'xJ8emTTy': '2022-07-24T16:49:54Z',
'cfyTOGxc': '2022-07-24T16:49:54Z',
}
}
for stream, new_state in simulated_states.items():
new_states['bookmarks'][stream] = new_state
menagerie.set_state(conn_id, new_states)
Expand Down
2 changes: 1 addition & 1 deletion tests/test_typeform_start_date.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ def test_run(self):
"""Instantiate start date according to the desired data set and run the test"""

self.start_date_1 = self.get_properties().get("start_date")
self.start_date_2 = self.timedelta_formatted(self.start_date_1, days=3)
self.start_date_2 = "2022-07-21T00:00:00Z"

self.start_date = self.start_date_1

Expand Down
44 changes: 44 additions & 0 deletions tests/unittests/test_sub_questions.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import unittest
from unittest import mock
from tap_typeform.streams import fetch_sub_questions
from parameterized import parameterized

class TestSubQuestionTest(unittest.TestCase):
@parameterized.expand([
["Question group have sub-questions",
{
'case1a': 'value1a', 'case1b': 'value1b', 'case1c': 'value1c',
'properties': {
'description': 'Group question',
'case1': 'value1','case2':'value2',
'fields': [
{
'id': 'id1', 'title': 'title1', 'ref': 'ref1'
},
{
'id': 'id2','title': 'title2', 'ref': 'title2'
}
]
},
'type': 'group'
},
[{'question_id': 'id1', 'title': 'title1', 'ref': 'ref1'}, {'question_id': 'id2', 'title': 'title2', 'ref': 'title2'}]
],
["Question group don't have sub-questions",
{
'case2a': 'value2a', 'case2b': 'value2b', 'case2c': 'value2c',
'properties': {
'description': 'Group question', 'case3':'value3', 'case4':'value4'
},
'type': 'group'
},
[]
]
])
def test_fetched_sub_question(self, test_name, test_value, expected_value):
"""
To verify that we are getting expected response or not for question group
"""

self.assertEqual(expected_value, fetch_sub_questions(test_value))