From 3012800b2150428107bd0164a931dfd3fad4552b Mon Sep 17 00:00:00 2001 From: Bruno Date: Sat, 31 Aug 2024 11:32:13 +0000 Subject: [PATCH] feat(migrate): add migration by type (csv, json, excel) --- hubmigrate/classes/migration.py | 36 ++++++++++++++++++----- hubmigrate/client.py | 4 +-- hubmigrate/requirements.txt | 3 +- hubmigrate/sample_company.xlsx | 2 ++ hubmigrate/tests/migrate_company_excel.py | 33 +++++++++++++++++++++ 5 files changed, 67 insertions(+), 11 deletions(-) create mode 100644 hubmigrate/sample_company.xlsx create mode 100644 hubmigrate/tests/migrate_company_excel.py diff --git a/hubmigrate/classes/migration.py b/hubmigrate/classes/migration.py index 3436745..0014638 100644 --- a/hubmigrate/classes/migration.py +++ b/hubmigrate/classes/migration.py @@ -1,5 +1,7 @@ import requests from .auth import Auth +import pandas as pd +import json class Migrate(): @@ -34,19 +36,37 @@ def get_data(self, params): print(f"Error retrieving data from {self.path} ❌") return data - - def post_data(self, data, path): + + def post_data(self, data, path, data_type='json'): """ Post data to path Arguments: - data {dict} -- Data to post to path + data {str or dict} -- Data to post to path (file path for Excel/CSV or dict for JSON) + path {str} -- HubSpot API path + data_type {str} -- Type of data ('json', 'excel', 'csv') """ - url = f"{self.base_path}/{path}" - response = requests.post(url, json=data, headers=self.headers) - if response.status_code in self.status_codes: - print(f"Successfully posted data to {url} 🎉") + if data_type == 'json': + if isinstance(data, str): + data_list = json.loads(data) + else: + data_list = data + elif data_type == 'excel': + df = pd.read_excel(data) + data_list = df.to_dict(orient='records') + elif data_type == 'csv': + df = pd.read_csv(data) + data_list = df.to_dict(orient='records') else: - print(f"Error posting data to {url}: {response.status_code} - {response.text} ❌") + raise ValueError("Unsupported data type. Use 'json', 'excel', or 'csv'.") + + # Post each record to HubSpot + for record in data_list: + url = f"{self.base_path}/{path}" + response = requests.post(url, json=record, headers=self.headers) + if response.status_code in self.status_codes: + print(f"Successfully posted data to {url} 🎉") + else: + print(f"Error posting data to {url}: {response.status_code} - {response.text} ❌") return response diff --git a/hubmigrate/client.py b/hubmigrate/client.py index 4278bbc..05a9af8 100644 --- a/hubmigrate/client.py +++ b/hubmigrate/client.py @@ -35,13 +35,13 @@ def delete_contact(self, contact_id): # Migrate companies - def migrate_company(self, data): + def migrate_company(self, data, data_type): """ Migrate company to HubSpot Arguments: data {dict} -- Data to migrate to HubSpot """ - return self.migrate.post_data(data, 'companies') + return self.migrate.post_data(data, 'companies', data_type) def update_company(self, data, company_id): """ Update company in HubSpot diff --git a/hubmigrate/requirements.txt b/hubmigrate/requirements.txt index 94883f3..50faade 100644 --- a/hubmigrate/requirements.txt +++ b/hubmigrate/requirements.txt @@ -1,4 +1,5 @@ pytest coverage python-decouple -requests \ No newline at end of file +requests +pandas \ No newline at end of file diff --git a/hubmigrate/sample_company.xlsx b/hubmigrate/sample_company.xlsx new file mode 100644 index 0000000..1719562 --- /dev/null +++ b/hubmigrate/sample_company.xlsx @@ -0,0 +1,2 @@ +name,country,city,address,zip,website,phone +Politie Utrecht,Netherland,Utrecht,Marco Pololaan 215,3526GB,https://www.politie.nl/,0900-8844 diff --git a/hubmigrate/tests/migrate_company_excel.py b/hubmigrate/tests/migrate_company_excel.py new file mode 100644 index 0000000..1537e7b --- /dev/null +++ b/hubmigrate/tests/migrate_company_excel.py @@ -0,0 +1,33 @@ +import unittest +from unittest.mock import Mock, patch +from hubmigrate.client import MigrationClient +from ..classes.auth import Auth +import pandas as pd +import os + + +class TestMigrateCompanyExcel(unittest.TestCase): + @patch('hubmigrate.client.MigrationClient.migrate_company', return_value=Mock(status_code=200)) + @patch('hubmigrate.classes.auth.Auth.get_token') + def test_migrate_company(self, mock_auth, mock_post): + # Create a test company + # Get the path to the current directory of your test script + current_dir = os.path.dirname(os.path.realpath(__file__)) + + # Define the relative path to your JSON file from the current directory + relative_path = '../sample_company.xlsx' + + # Construct the full file path + excel_file_path = os.path.join(current_dir, relative_path) + path = excel_file_path + with open(path) as f: + test_company = pd.read_excel(f) + + # Create an instance of the MigrationClient class + client = MigrationClient('config', 'hubspot') + + # Call the migrate_company method + result = client.migrate_company({'properties': test_company}, 'excel') + + # Assertions + self.assertEqual(result.status_code, 200) \ No newline at end of file