def main(account_id, passcode, path, type, dryrun): clevertap = CleverTap(account_id, passcode) data = [] if type not in ["event", "profile"]: raise Exception("unknown record type %s" % type) return if type == "event": raise NotImplementedError("Event handling not yet implemented") return f = open(path, 'rt') try: reader = csv.DictReader(f) for row in reader: record = process_raw_record(row, type) if record is not None: if dryrun: print record data.append(record) else: print "unable to process row skipping: %s" % row count = len(data) if count <= 0: print "no records to process" f.close() return if not dryrun: print "starting upload for %s records" % count processed = 0 while processed < count: remaining = count - processed batch_size = MAX_BATCH_SIZE if remaining > MAX_BATCH_SIZE else remaining batch = data[processed:processed + batch_size] if not dryrun: res = clevertap.upload(batch) print res processed += batch_size print "processed %s records" % processed except Exception, e: print e
continue data.append(push_data) if can_email: email_data = {'type': 'event', 'ts': ts, 'evtName': 'newQuoteEmail', 'evtData': {"value":quote, "quoteId":quote_id} } # add the identity value if identity is not None: email_data['identity'] = identity elif object_id is not None: email_data['objectId'] = object_id else: continue data.append(email_data) if len(data) > 0: clevertap.upload(data) return True if __name__ == '__main__': handler({"tz_string":"UTC-7"}, None)
class CleverTapTests(unittest.TestCase): def setUp(self): self.clevertap = CleverTap(CT_ACCOUNT_ID, CT_ACCOUNT_PASSCODE) def test_upload(self): data = [ {"type":"event", "identity":"6264372124", "evtName":"choseNewFavoriteFood", "evtData":{ "value":random.choice(foods), }, }, {"type":"profile", "identity":"6264372124", "ts":int(time.time()), "profileData":{ "favoriteColor":random.choice(colors), "Age":30, "Phone":"+14155551234", "Email":"*****@*****.**", }, }, {"type":"event", "FBID":"34322423", "evtName":"Product viewed", "evtData":{ "Product name":"Casio Chronograph Watch", "Category":"Mens Watch", "Price":59.99, "Currency":"USD" }, }, {'type': 'profile', 'objectId': "-2ce3cca260664f70b82b1c6bb505f462", 'profileData': {'favoriteFood': 'hot dogs'} }, {'type': 'event', 'objectId': "-2ce3cca260664f70b82b1c6bb505f462", 'evtName': 'choseNewFavoriteFood', 'evtData': {} }, {"type":"event", "identity":"*****@*****.**", "ts":"%s"%int(time.time()), "evtName":"Charged", "evtData":{ "Amount":300, "Currency":"USD", "Payment mode":"Credit Card", "Items":[ { "Category":"books", "Book name":"The millionaire next door", "Quantity":1 }, { "Category":"books", "Book name":"Achieving inner zen", "Quantity":4 } ] }, }, ] res = self.clevertap.upload(data) or {} unprocessed = res.get("unprocessed", []) self.assertEqual(len(unprocessed), 0, "%s records failed"%(len(unprocessed))) def test_download_events(self): query = {"event_name": "choseNewFavoriteFood", "props": [{"name":"value","operator":"contains", "value":"piz"}], "from": 20160810, "to": 20170208 } res = self.clevertap.events(query) if len(res) > 0: print res[0] self.assertTrue( len(res) > 0 ) def test_download_profiles(self): query = {"event_name": "choseNewFavoriteFood", "props": [{"name":"value","operator":"contains", "value":"piz"}], "from": 20160810, "to": 20170208 } res = self.clevertap.profiles(query) if len(res) > 0: print res[0] self.assertTrue( len(res) > 0 ) def test_profile_by_id(self): res = self.clevertap.profile(identity="6264372124") or {} print res self.assertTrue( res.get("status", None) == "success" )
email_data = { 'type': 'event', 'ts': ts, 'evtName': 'newQuoteEmail', 'evtData': { "value": quote, "quoteId": quote_id } } # add the identity value if identity is not None: email_data['identity'] = identity elif object_id is not None: email_data['objectId'] = object_id else: continue data.append(email_data) if len(data) > 0: clevertap.upload(data) return True if __name__ == '__main__': handler({"tz_string": "UTC-7"}, None)