Skip to content

Commit

Permalink
Merge branch 'master' of github.com:singer-io/tap-intercom into TDL-2…
Browse files Browse the repository at this point in the history
…5597/conversations-schema-update
  • Loading branch information
rdeshmukh15 committed May 8, 2024
2 parents 4417390 + 8c6bbc5 commit c0984b6
Show file tree
Hide file tree
Showing 7 changed files with 88 additions and 26 deletions.
22 changes: 18 additions & 4 deletions tests/test_all_fields.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,15 @@ class IntercomAllFields(IntercomBaseTest):
# Fields for which we cannot generate data
fields_to_remove = {
'company_attributes': {
'options'
'options',
'admin_id'
},
'companies': {
'size',
'website',
'industry',
'segments'
'segments',
'tags'
},
'conversations': {
'user',
Expand All @@ -32,9 +34,21 @@ class IntercomAllFields(IntercomBaseTest):
'admin_ids'
},
'contact_attributes': {
'options'
'options',
'admin_id'
},
'contacts': {
'tags'
}
}

def get_properties(self):
"""Configuration properties required for the tap."""
return_value = {
'start_date' : "2016-01-01T00:00:00Z"
}
return return_value

@staticmethod
def name():
return "tap_tester_intercom_all_fields"
Expand All @@ -47,7 +61,7 @@ def test_run(self):
"""
# Created card for untestable/unstable streams.
# FIX CARD: https://jira.talendforge.org/browse/TDL-17035
untestable_streams = {"segments"}
untestable_streams = {"tags", "segments" ,"conversation_parts", "conversations", "company_segments"}
expected_streams = self.expected_streams().difference(untestable_streams)

# instantiate connection
Expand Down
9 changes: 8 additions & 1 deletion tests/test_intercom_automatic_fields.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,13 @@ class IntercomAutomaticFields(IntercomBaseTest):
def name():
return "tap_tester_intercom_automatic_fields"

def get_properties(self):
"""Configuration properties required for the tap."""
return_value = {
'start_date' : "2016-01-01T00:00:00Z"
}
return return_value

def test_run(self):
"""
Verify that for each stream you can get multiple pages of data
Expand All @@ -25,7 +32,7 @@ def test_run(self):
"""
# Created card for untestable/unstable streams.
# FIX CARD: https://jira.talendforge.org/browse/TDL-17035
untestable_streams = {"segments"}
untestable_streams = {"conversation_parts", "conversations", "segments", "tags", "company_segments"}
expected_streams = self.expected_streams().difference(untestable_streams)

# Instantiate connection
Expand Down
44 changes: 33 additions & 11 deletions tests/test_intercom_bookmarks.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,18 @@ class IntercomBookmarks(IntercomBaseTest):
def name():
return "tap_tester_intercom_bookmarks"

def first_start_date(self, original: bool = True):
"""Configuration properties required for the tap."""
return {
'start_date' : "2015-06-15T00:00:00Z"
}

def second_start_date(self, original: bool = True):
"""Configuration properties required for the tap."""
return {
'start_date' : "2016-01-01T00:00:00Z"
}

def calculated_states_by_stream(self, current_state):
"""
Look at the bookmarks from a previous sync and set a new bookmark
Expand Down Expand Up @@ -51,6 +63,23 @@ def calculated_states_by_stream(self, current_state):
return stream_to_calculated_state

def test_run(self):
# Created card for untestable/unstable streams.
# FIX CARD: https://jira.talendforge.org/browse/TDL-17035
# The "conversation_parts" stream is a sub-stream that relies on the bookmark of its parent stream, "conversations".
# Hence, the stream is skipped.
untestable_streams = {"segments", "company_segments", "conversation_parts", "tags", "conversations", "companies"}
expected_streams_1 = self.expected_streams() - untestable_streams
self.get_properties = self.first_start_date
self.start_date = self.get_properties().get('start_date')
self.run_test(expected_streams_1, self.start_date)

# Setting a different start date to test "companies" stream.
self.get_properties = self.second_start_date
self.start_date = self.get_properties().get('start_date')
expected_streams_2 = {"companies"}
self.run_test(expected_streams_2, self.start_date, True)

def run_test(self, expected_streams, start_date, stream_assert=False):
"""
Verify that:
For each stream, you can do a sync that records bookmarks.
Expand All @@ -68,15 +97,6 @@ def test_run(self):
different values for the replication key
"""

# Created card for untestable/unstable streams.
# FIX CARD: https://jira.talendforge.org/browse/TDL-17035
# The stream: "conversation_parts" is child stream and bookmark is being written of parent stream. Thus, skipping the stream
untestable_streams = {"companies", "segments", "company_segments", "conversation_parts"}
# Contacts stream does 3 API calls for addressable list fields, [notes, companies, tags]
# This cause the build to run more than 3 hrs, thus skipping this stream
streams_to_skip = {"contacts"}
expected_streams = self.expected_streams() - untestable_streams - streams_to_skip

expected_replication_keys = self.expected_replication_keys()
expected_replication_methods = self.expected_replication_method()

Expand Down Expand Up @@ -120,7 +140,6 @@ def test_run(self):
### Test By Stream
##########################################################################

start_date = self.get_properties().get('start_date')
for stream in expected_streams:
with self.subTest(stream=stream):

Expand Down Expand Up @@ -190,7 +209,10 @@ def test_run(self):
msg="Second sync records do not respect the previous bookmark.")

# Verify the number of records in the 2nd sync is less then the first
self.assertLess(second_sync_count, first_sync_count)
if stream_assert:
self.assertLessEqual(second_sync_count, first_sync_count)
else:
self.assertLess(second_sync_count, first_sync_count)

elif expected_replication_method == self.FULL_TABLE:

Expand Down
2 changes: 1 addition & 1 deletion tests/test_intercom_interrupted_sync.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ def test_run(self):

conn_id = connections.ensure_connection(self, original_properties=False)

expected_streams = {"company_segments", "conversations", "segments", "admins"}
expected_streams = {"company_segments", "conversations", "segments", "admins", "contacts", "companies"}

# Run check mode
found_catalogs = self.run_and_verify_check_mode(conn_id)
Expand Down
21 changes: 13 additions & 8 deletions tests/test_intercom_pagination.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,25 +13,30 @@ class RechargePaginationTest(IntercomBaseTest):
def name():
return "tap_tester_intercom_pagination_test"

def get_properties(self):
"""Configuration properties required for the tap."""
return_value = {
'start_date' : "2016-01-01T00:00:00Z"
}
return return_value

def test_run(self):
"""
Verify that for each stream you can get multiple pages of data
and that when all fields are selected more than the automatic fields are replicated.
PREREQUISITE
For EACH stream add enough data that you surpass the limit of a single
fetch of data. For instance if you have a limit of 150 records ensure
that 151 (or more) records have been posted for that stream.
fetch of data. For instance if you have a limit of 100 records ensure
that 101 (or more) records have been posted for that stream.
"""
page_size = 150
page_size = 50
conn_id = connections.ensure_connection(self)

# Checking pagination for streams having enough data
expected_streams = [
"conversations",
# The Contacts stream API has a delay in updating the records. Thus, we are getting some duplicate records.
# Reference Ticket: https://jira.talendforge.org/browse/TDL-19860
# "contacts",
"tags",
# "conversations",
"contacts",
# "tags",
"companies"
]
found_catalogs = self.run_and_verify_check_mode(conn_id)
Expand Down
7 changes: 7 additions & 0 deletions tests/test_intercom_parent_child_sync.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,18 @@
from datetime import datetime as dt, timedelta
from tap_tester import runner, menagerie, connections
from base import IntercomBaseTest
import unittest

class IntercomParentChildSync(IntercomBaseTest):
@staticmethod
def name():
return "tap_tester_intercom_parent_child_sync"

@unittest.expectedFailure
def test_run(self):
# Once suficiennt data is generated for the test, remove below line
self.assertFalse(True, "X-Failing this test due to insufficient test data.")

# Run with parent stream as earlier bookmark
self.run_test(
child_bookmark=(dt.now()).strftime(self.START_DATE_FORMAT),
Expand All @@ -33,6 +38,8 @@ def run_test(self, child_bookmark, parent_bookmark, earlier_stream):
- Verify we sync some records for the earlier stream which is between the
both the bookmark dates ie. child stream bookmark and parent streams bookmark
"""
# Need a subscription to generate sufficient data for testing,
# But verified with separate credentials that the test is working as expected.
expected_streams = {"conversations", "conversation_parts"}

# Create state file
Expand Down
9 changes: 8 additions & 1 deletion tests/test_intercom_start_date.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,13 @@ class IntercomStartDateTest(IntercomBaseTest):
def name():
return "tap_tester_intercom_start_date_test"

def get_properties(self, original: bool = True):
"""Configuration properties required for the tap."""
return_value = {
'start_date' : "2016-01-01T00:00:00Z"
}
return return_value

def test_run(self):
"""
Test that the start_date configuration is respected
Expand All @@ -25,7 +32,7 @@ def test_run(self):
"""
# Created card for untestable/unstable streams.
# FIX CARD: https://jira.talendforge.org/browse/TDL-17035
untestable_streams = {"segments", "companies","conversation_parts"}
untestable_streams = {"segments", "company_segments", "conversations", "companies", "conversation_parts"}
expected_streams = self.expected_streams().difference(untestable_streams)

self.start_date_1 = self.get_properties().get('start_date')
Expand Down

0 comments on commit c0984b6

Please sign in to comment.