|
| 1 | + |
1 | 2 | # Databricks CLI |
2 | 3 | # Copyright 2017 Databricks, Inc. |
3 | 4 | # |
|
31 | 32 | from databricks_cli.workspace.types import WorkspaceLanguage |
32 | 33 |
|
33 | 34 | TEST_WORKSPACE_PATH = '/test/workspace/path' |
| 35 | +TEST_WORKSPACE_OBJECT_ID = '22' |
34 | 36 | TEST_JSON_RESPONSE = { |
35 | 37 | 'path': TEST_WORKSPACE_PATH, |
36 | 38 | 'object_type': api.DIRECTORY, |
37 | | - 'created_at': 124 |
| 39 | + 'created_at': 124, |
| 40 | + 'object_id': TEST_WORKSPACE_OBJECT_ID, |
38 | 41 | } |
39 | 42 | TEST_LANGUAGE = 'PYTHON' |
40 | 43 | TEST_FMT = 'SOURCE' |
41 | 44 |
|
42 | 45 |
|
43 | 46 | class TestWorkspaceFileInfo(object): |
44 | 47 | def test_to_row_not_long_form_not_absolute(self): |
45 | | - file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK) |
| 48 | + file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK, |
| 49 | + TEST_WORKSPACE_OBJECT_ID) |
46 | 50 | row = file_info.to_row(is_long_form=False, is_absolute=False) |
47 | 51 | assert len(row) == 1 |
48 | 52 | assert row[0] == file_info.basename |
49 | 53 |
|
50 | 54 | def test_to_row_not_long_form_absolute(self): |
51 | | - file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK) |
| 55 | + file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK, |
| 56 | + TEST_WORKSPACE_OBJECT_ID) |
52 | 57 | row = file_info.to_row(is_long_form=False, is_absolute=True) |
53 | 58 | assert len(row) == 1 |
54 | 59 | assert row[0] == TEST_WORKSPACE_PATH |
55 | 60 |
|
56 | 61 | def test_to_row_long_form_absolute(self): |
57 | | - file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK) |
| 62 | + file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK, |
| 63 | + TEST_WORKSPACE_OBJECT_ID) |
58 | 64 | row = file_info.to_row(is_long_form=True, is_absolute=True) |
59 | 65 | assert len(row) == 3 |
60 | 66 | assert row[0] == api.NOTEBOOK |
61 | 67 | assert row[1] == TEST_WORKSPACE_PATH |
62 | 68 | assert row[2] is None |
63 | 69 |
|
64 | 70 | def test_basename(self): |
65 | | - file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK) |
| 71 | + file_info = api.WorkspaceFileInfo(TEST_WORKSPACE_PATH, api.NOTEBOOK, |
| 72 | + TEST_WORKSPACE_OBJECT_ID) |
66 | 73 | assert file_info.basename == 'path' |
67 | 74 |
|
68 | 75 | def test_from_json(self): |
@@ -104,8 +111,8 @@ def test_import_workspace(self, workspace_api, tmpdir): |
104 | 111 | test_file_path = os.path.join(tmpdir.strpath, 'test') |
105 | 112 | with open(test_file_path, 'w') as f: |
106 | 113 | f.write('test') |
107 | | - workspace_api.import_workspace(test_file_path, TEST_WORKSPACE_PATH, TEST_LANGUAGE, TEST_FMT, |
108 | | - is_overwrite=False) |
| 114 | + workspace_api.import_workspace(test_file_path, TEST_WORKSPACE_PATH, TEST_LANGUAGE, |
| 115 | + TEST_FMT, is_overwrite=False) |
109 | 116 | import_workspace_mock = workspace_api.client.import_workspace |
110 | 117 | assert import_workspace_mock.call_count == 1 |
111 | 118 | assert import_workspace_mock.call_args[0][0] == TEST_WORKSPACE_PATH |
@@ -147,18 +154,22 @@ def test_export_workspace_dir(self, workspace_api, tmpdir): |
147 | 154 | def _list_objects_mock(path, headers=None): |
148 | 155 | if path == '/': |
149 | 156 | return [ |
150 | | - WorkspaceFileInfo('/a', api.DIRECTORY), |
151 | | - WorkspaceFileInfo('/f', api.DIRECTORY) |
| 157 | + WorkspaceFileInfo('/a', api.DIRECTORY, TEST_WORKSPACE_OBJECT_ID), |
| 158 | + WorkspaceFileInfo('/f', api.DIRECTORY, TEST_WORKSPACE_OBJECT_ID) |
152 | 159 | ] |
153 | 160 | elif path == '/a': |
154 | 161 | return [ |
155 | | - WorkspaceFileInfo('/a/b', api.NOTEBOOK, WorkspaceLanguage.SCALA), |
156 | | - WorkspaceFileInfo('/a/c', api.NOTEBOOK, WorkspaceLanguage.PYTHON), |
157 | | - WorkspaceFileInfo('/a/d', api.NOTEBOOK, WorkspaceLanguage.R), |
158 | | - WorkspaceFileInfo('/a/e', api.NOTEBOOK, WorkspaceLanguage.SQL), |
| 162 | + WorkspaceFileInfo('/a/b', api.NOTEBOOK, TEST_WORKSPACE_OBJECT_ID, |
| 163 | + WorkspaceLanguage.SCALA), |
| 164 | + WorkspaceFileInfo('/a/c', api.NOTEBOOK, TEST_WORKSPACE_OBJECT_ID, |
| 165 | + WorkspaceLanguage.PYTHON), |
| 166 | + WorkspaceFileInfo('/a/d', api.NOTEBOOK, TEST_WORKSPACE_OBJECT_ID, |
| 167 | + WorkspaceLanguage.R), |
| 168 | + WorkspaceFileInfo('/a/e', api.NOTEBOOK, TEST_WORKSPACE_OBJECT_ID, |
| 169 | + WorkspaceLanguage.SQL), |
159 | 170 | ] |
160 | 171 | elif path == '/f': |
161 | | - return [WorkspaceFileInfo('/f/g', api.DIRECTORY)] |
| 172 | + return [WorkspaceFileInfo('/f/g', api.DIRECTORY, TEST_WORKSPACE_OBJECT_ID)] |
162 | 173 | elif path == '/f/g': |
163 | 174 | return [] |
164 | 175 | else: |
|
0 commit comments