@assistant-ui/react 0.10.23 → 0.10.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (189) hide show
  1. package/dist/cloud/AssistantCloudThreadHistoryAdapter.d.ts +1 -1
  2. package/dist/cloud/AssistantCloudThreadHistoryAdapter.d.ts.map +1 -1
  3. package/dist/cloud/AssistantCloudThreadHistoryAdapter.js.map +1 -1
  4. package/dist/cloud/auiV0.d.ts +1 -1
  5. package/dist/cloud/auiV0.d.ts.map +1 -1
  6. package/dist/cloud/auiV0.js.map +1 -1
  7. package/dist/cloud/index.d.ts +1 -1
  8. package/dist/cloud/index.d.ts.map +1 -1
  9. package/dist/cloud/index.js +1 -1
  10. package/dist/cloud/index.js.map +1 -1
  11. package/dist/cloud/useCloudThreadListRuntime.d.ts +1 -1
  12. package/dist/cloud/useCloudThreadListRuntime.d.ts.map +1 -1
  13. package/dist/cloud/useCloudThreadListRuntime.js.map +1 -1
  14. package/dist/context/react/AssistantContext.d.ts +23 -0
  15. package/dist/context/react/AssistantContext.d.ts.map +1 -1
  16. package/dist/context/react/AssistantContext.js.map +1 -1
  17. package/dist/context/react/ComposerContext.d.ts +64 -0
  18. package/dist/context/react/ComposerContext.d.ts.map +1 -1
  19. package/dist/context/react/ComposerContext.js.map +1 -1
  20. package/dist/context/react/MessageContext.d.ts +56 -0
  21. package/dist/context/react/MessageContext.d.ts.map +1 -1
  22. package/dist/context/react/MessageContext.js.map +1 -1
  23. package/dist/context/react/ThreadContext.d.ts +42 -0
  24. package/dist/context/react/ThreadContext.d.ts.map +1 -1
  25. package/dist/context/react/ThreadContext.js.map +1 -1
  26. package/dist/primitives/actionBar/ActionBarCopy.d.ts +42 -0
  27. package/dist/primitives/actionBar/ActionBarCopy.d.ts.map +1 -1
  28. package/dist/primitives/actionBar/ActionBarCopy.js.map +1 -1
  29. package/dist/primitives/actionBar/ActionBarEdit.d.ts +38 -0
  30. package/dist/primitives/actionBar/ActionBarEdit.d.ts.map +1 -1
  31. package/dist/primitives/actionBar/ActionBarEdit.js.map +1 -1
  32. package/dist/primitives/actionBar/ActionBarReload.d.ts +39 -0
  33. package/dist/primitives/actionBar/ActionBarReload.d.ts.map +1 -1
  34. package/dist/primitives/actionBar/ActionBarReload.js.map +1 -1
  35. package/dist/primitives/actionBar/ActionBarRoot.d.ts +56 -0
  36. package/dist/primitives/actionBar/ActionBarRoot.d.ts.map +1 -1
  37. package/dist/primitives/actionBar/ActionBarRoot.js.map +1 -1
  38. package/dist/primitives/attachment/AttachmentRoot.d.ts +18 -0
  39. package/dist/primitives/attachment/AttachmentRoot.d.ts.map +1 -1
  40. package/dist/primitives/attachment/AttachmentRoot.js.map +1 -1
  41. package/dist/primitives/branchPicker/BranchPickerCount.d.ts +17 -0
  42. package/dist/primitives/branchPicker/BranchPickerCount.d.ts.map +1 -1
  43. package/dist/primitives/branchPicker/BranchPickerCount.js.map +1 -1
  44. package/dist/primitives/branchPicker/BranchPickerNext.d.ts +17 -0
  45. package/dist/primitives/branchPicker/BranchPickerNext.d.ts.map +1 -1
  46. package/dist/primitives/branchPicker/BranchPickerNext.js.map +1 -1
  47. package/dist/primitives/branchPicker/BranchPickerPrevious.d.ts +38 -0
  48. package/dist/primitives/branchPicker/BranchPickerPrevious.d.ts.map +1 -1
  49. package/dist/primitives/branchPicker/BranchPickerPrevious.js.map +1 -1
  50. package/dist/primitives/branchPicker/BranchPickerRoot.d.ts +27 -0
  51. package/dist/primitives/branchPicker/BranchPickerRoot.d.ts.map +1 -1
  52. package/dist/primitives/branchPicker/BranchPickerRoot.js.map +1 -1
  53. package/dist/primitives/composer/ComposerAttachments.d.ts.map +1 -1
  54. package/dist/primitives/composer/ComposerAttachments.js +11 -8
  55. package/dist/primitives/composer/ComposerAttachments.js.map +1 -1
  56. package/dist/primitives/composer/ComposerCancel.d.ts +17 -0
  57. package/dist/primitives/composer/ComposerCancel.d.ts.map +1 -1
  58. package/dist/primitives/composer/ComposerCancel.js.map +1 -1
  59. package/dist/primitives/composer/ComposerInput.d.ts +72 -0
  60. package/dist/primitives/composer/ComposerInput.d.ts.map +1 -1
  61. package/dist/primitives/composer/ComposerInput.js.map +1 -1
  62. package/dist/primitives/composer/ComposerRoot.d.ts +19 -0
  63. package/dist/primitives/composer/ComposerRoot.d.ts.map +1 -1
  64. package/dist/primitives/composer/ComposerRoot.js.map +1 -1
  65. package/dist/primitives/composer/ComposerSend.d.ts +18 -0
  66. package/dist/primitives/composer/ComposerSend.d.ts.map +1 -1
  67. package/dist/primitives/composer/ComposerSend.js.map +1 -1
  68. package/dist/primitives/contentPart/ContentPartImage.d.ts +19 -0
  69. package/dist/primitives/contentPart/ContentPartImage.d.ts.map +1 -1
  70. package/dist/primitives/contentPart/ContentPartImage.js.map +1 -1
  71. package/dist/primitives/contentPart/ContentPartText.d.ts +34 -0
  72. package/dist/primitives/contentPart/ContentPartText.d.ts.map +1 -1
  73. package/dist/primitives/contentPart/ContentPartText.js.map +1 -1
  74. package/dist/primitives/message/MessageAttachments.d.ts.map +1 -1
  75. package/dist/primitives/message/MessageAttachments.js +11 -8
  76. package/dist/primitives/message/MessageAttachments.js.map +1 -1
  77. package/dist/primitives/message/MessageContent.d.ts +41 -0
  78. package/dist/primitives/message/MessageContent.d.ts.map +1 -1
  79. package/dist/primitives/message/MessageContent.js +14 -11
  80. package/dist/primitives/message/MessageContent.js.map +1 -1
  81. package/dist/primitives/message/MessageRoot.d.ts +22 -0
  82. package/dist/primitives/message/MessageRoot.d.ts.map +1 -1
  83. package/dist/primitives/message/MessageRoot.js.map +1 -1
  84. package/dist/primitives/thread/ThreadMessages.d.ts +44 -0
  85. package/dist/primitives/thread/ThreadMessages.d.ts.map +1 -1
  86. package/dist/primitives/thread/ThreadMessages.js +5 -2
  87. package/dist/primitives/thread/ThreadMessages.js.map +1 -1
  88. package/dist/primitives/thread/ThreadRoot.d.ts +19 -0
  89. package/dist/primitives/thread/ThreadRoot.d.ts.map +1 -1
  90. package/dist/primitives/thread/ThreadRoot.js.map +1 -1
  91. package/dist/primitives/thread/ThreadViewport.d.ts +24 -0
  92. package/dist/primitives/thread/ThreadViewport.d.ts.map +1 -1
  93. package/dist/primitives/thread/ThreadViewport.js.map +1 -1
  94. package/dist/primitives/threadList/ThreadListItems.d.ts.map +1 -1
  95. package/dist/primitives/threadList/ThreadListItems.js +12 -9
  96. package/dist/primitives/threadList/ThreadListItems.js.map +1 -1
  97. package/dist/runtimes/adapters/attachment/AttachmentAdapter.d.ts +54 -0
  98. package/dist/runtimes/adapters/attachment/AttachmentAdapter.d.ts.map +1 -1
  99. package/dist/runtimes/adapters/feedback/FeedbackAdapter.d.ts +33 -0
  100. package/dist/runtimes/adapters/feedback/FeedbackAdapter.d.ts.map +1 -1
  101. package/dist/runtimes/adapters/speech/SpeechAdapterTypes.d.ts +47 -0
  102. package/dist/runtimes/adapters/speech/SpeechAdapterTypes.d.ts.map +1 -1
  103. package/dist/runtimes/local/LocalRuntimeOptions.d.ts +2 -2
  104. package/dist/runtimes/local/LocalRuntimeOptions.d.ts.map +1 -1
  105. package/dist/runtimes/local/LocalRuntimeOptions.js.map +1 -1
  106. package/dist/runtimes/remote-thread-list/adapter/cloud.d.ts +1 -1
  107. package/dist/runtimes/remote-thread-list/adapter/cloud.d.ts.map +1 -1
  108. package/dist/runtimes/remote-thread-list/adapter/cloud.js +1 -1
  109. package/dist/runtimes/remote-thread-list/adapter/cloud.js.map +1 -1
  110. package/dist/tests/setup.js +8 -8
  111. package/dist/tests/setup.js.map +1 -1
  112. package/package.json +8 -7
  113. package/src/cloud/AssistantCloudThreadHistoryAdapter.tsx +1 -1
  114. package/src/cloud/auiV0.ts +1 -1
  115. package/src/cloud/index.ts +1 -1
  116. package/src/cloud/useCloudThreadListRuntime.tsx +1 -1
  117. package/src/context/react/AssistantContext.ts +23 -0
  118. package/src/context/react/ComposerContext.ts +64 -0
  119. package/src/context/react/MessageContext.ts +56 -0
  120. package/src/context/react/ThreadContext.ts +42 -0
  121. package/src/primitives/actionBar/ActionBarCopy.tsx +42 -0
  122. package/src/primitives/actionBar/ActionBarEdit.tsx +38 -0
  123. package/src/primitives/actionBar/ActionBarReload.tsx +39 -0
  124. package/src/primitives/actionBar/ActionBarRoot.tsx +38 -0
  125. package/src/primitives/attachment/AttachmentRoot.tsx +18 -0
  126. package/src/primitives/branchPicker/BranchPickerCount.tsx +17 -0
  127. package/src/primitives/branchPicker/BranchPickerNext.tsx +17 -0
  128. package/src/primitives/branchPicker/BranchPickerPrevious.tsx +38 -0
  129. package/src/primitives/branchPicker/BranchPickerRoot.tsx +22 -0
  130. package/src/primitives/composer/ComposerAttachments.tsx +11 -7
  131. package/src/primitives/composer/ComposerCancel.tsx +17 -0
  132. package/src/primitives/composer/ComposerInput.tsx +44 -0
  133. package/src/primitives/composer/ComposerRoot.tsx +19 -0
  134. package/src/primitives/composer/ComposerSend.tsx +18 -0
  135. package/src/primitives/contentPart/ContentPartImage.tsx +19 -0
  136. package/src/primitives/contentPart/ContentPartText.tsx +25 -0
  137. package/src/primitives/message/MessageAttachments.tsx +11 -7
  138. package/src/primitives/message/MessageContent.tsx +54 -18
  139. package/src/primitives/message/MessageRoot.tsx +22 -0
  140. package/src/primitives/thread/ThreadMessages.tsx +52 -4
  141. package/src/primitives/thread/ThreadRoot.tsx +19 -0
  142. package/src/primitives/thread/ThreadViewport.tsx +19 -0
  143. package/src/primitives/threadList/ThreadListItems.tsx +12 -8
  144. package/src/runtimes/adapters/attachment/AttachmentAdapter.ts +56 -0
  145. package/src/runtimes/adapters/feedback/FeedbackAdapter.ts +33 -0
  146. package/src/runtimes/adapters/speech/SpeechAdapterTypes.ts +47 -0
  147. package/src/runtimes/local/LocalRuntimeOptions.tsx +1 -1
  148. package/src/runtimes/remote-thread-list/adapter/cloud.tsx +1 -1
  149. package/dist/cloud/AssistantCloud.d.ts +0 -15
  150. package/dist/cloud/AssistantCloud.d.ts.map +0 -1
  151. package/dist/cloud/AssistantCloud.js +0 -25
  152. package/dist/cloud/AssistantCloud.js.map +0 -1
  153. package/dist/cloud/AssistantCloudAPI.d.ts +0 -28
  154. package/dist/cloud/AssistantCloudAPI.d.ts.map +0 -1
  155. package/dist/cloud/AssistantCloudAPI.js +0 -87
  156. package/dist/cloud/AssistantCloudAPI.js.map +0 -1
  157. package/dist/cloud/AssistantCloudAuthStrategy.d.ts +0 -30
  158. package/dist/cloud/AssistantCloudAuthStrategy.d.ts.map +0 -1
  159. package/dist/cloud/AssistantCloudAuthStrategy.js +0 -139
  160. package/dist/cloud/AssistantCloudAuthStrategy.js.map +0 -1
  161. package/dist/cloud/AssistantCloudAuthTokens.d.ts +0 -11
  162. package/dist/cloud/AssistantCloudAuthTokens.d.ts.map +0 -1
  163. package/dist/cloud/AssistantCloudAuthTokens.js +0 -13
  164. package/dist/cloud/AssistantCloudAuthTokens.js.map +0 -1
  165. package/dist/cloud/AssistantCloudFiles.d.ts +0 -27
  166. package/dist/cloud/AssistantCloudFiles.d.ts.map +0 -1
  167. package/dist/cloud/AssistantCloudFiles.js +0 -25
  168. package/dist/cloud/AssistantCloudFiles.js.map +0 -1
  169. package/dist/cloud/AssistantCloudRuns.d.ts +0 -26
  170. package/dist/cloud/AssistantCloudRuns.d.ts.map +0 -1
  171. package/dist/cloud/AssistantCloudRuns.js +0 -39
  172. package/dist/cloud/AssistantCloudRuns.js.map +0 -1
  173. package/dist/cloud/AssistantCloudThreadMessages.d.ts +0 -30
  174. package/dist/cloud/AssistantCloudThreadMessages.d.ts.map +0 -1
  175. package/dist/cloud/AssistantCloudThreadMessages.js +0 -21
  176. package/dist/cloud/AssistantCloudThreadMessages.js.map +0 -1
  177. package/dist/cloud/AssistantCloudThreads.d.ts +0 -48
  178. package/dist/cloud/AssistantCloudThreads.d.ts.map +0 -1
  179. package/dist/cloud/AssistantCloudThreads.js +0 -30
  180. package/dist/cloud/AssistantCloudThreads.js.map +0 -1
  181. package/src/cloud/AssistantCloud.tsx +0 -22
  182. package/src/cloud/AssistantCloudAPI.tsx +0 -121
  183. package/src/cloud/AssistantCloudAuthStrategy.tsx +0 -193
  184. package/src/cloud/AssistantCloudAuthTokens.tsx +0 -13
  185. package/src/cloud/AssistantCloudFiles.tsx +0 -48
  186. package/src/cloud/AssistantCloudRuns.tsx +0 -45
  187. package/src/cloud/AssistantCloudThreadMessages.tsx +0 -48
  188. package/src/cloud/AssistantCloudThreads.tsx +0 -79
  189. package/src/tests/AssistantCloudFiles.test.ts +0 -564
@@ -1,564 +0,0 @@
1
- import { describe, it, expect, beforeEach, vi, afterEach } from "vitest";
2
- import { AssistantCloudFiles } from "../cloud/AssistantCloudFiles";
3
- import { AssistantCloudAPI } from "../cloud/AssistantCloudAPI";
4
-
5
- // Mock the AssistantCloudAPI to avoid making real HTTP requests (except for integration tests)
6
- vi.mock("../cloud/AssistantCloudAPI");
7
-
8
- describe("AssistantCloudFiles", () => {
9
- let cloudFiles: AssistantCloudFiles;
10
- let mockApi: AssistantCloudAPI;
11
-
12
- beforeEach(() => {
13
- // Create a mock API instance
14
- mockApi = {
15
- makeRequest: vi.fn(),
16
- makeRawRequest: vi.fn(),
17
- _auth: { getAuthHeaders: vi.fn() },
18
- _baseUrl: "https://backend.assistant-api.com",
19
- } as unknown as AssistantCloudAPI;
20
-
21
- // Create the AssistantCloudFiles instance with the mock API
22
- cloudFiles = new AssistantCloudFiles(mockApi);
23
- });
24
-
25
- afterEach(() => {
26
- vi.clearAllMocks();
27
- });
28
-
29
- describe("pdfToImages", () => {
30
- /**
31
- * Tests successful PDF to images conversion with file_url
32
- * This matches the curl request structure provided
33
- */
34
- it("should successfully convert PDF to images using file_url", async () => {
35
- const mockResponse = {
36
- success: true,
37
- urls: [
38
- "https://aui-pdf-processing.5c52327048f352f85fb041947c406ab4.r2.cloudflarestorage.com/images/8eb81c61-dc76-48fd-ab66-25cd84a28c97/page-1.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=8698a7e98d990c6edd11fee3a9d0f3f0%2F20250606%2Fauto%2Fs3%2Faws4_request&X-Amz-Date=20250606T035428Z&X-Amz-Expires=3600&X-Amz-Signature=ea26cdd5ff7dc85eba12970137606484b9a8ab2c520f31ddba9cbe5941b20793&X-Amz-SignedHeaders=host&x-amz-checksum-mode=ENABLED&x-id=GetObject",
39
- "https://aui-pdf-processing.5c52327048f352f85fb041947c406ab4.r2.cloudflarestorage.com/images/8eb81c61-dc76-48fd-ab66-25cd84a28c97/page-2.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=8698a7e98d990c6edd11fee3a9d0f3f0%2F20250606%2Fauto%2Fs3%2Faws4_request&X-Amz-Date=20250606T035428Z&X-Amz-Expires=3600&X-Amz-Signature=3499237770cc4402a60e6cc9b8ce8bd460faade9adf456d2773009f7d07af9cb&X-Amz-SignedHeaders=host&x-amz-checksum-mode=ENABLED&x-id=GetObject",
40
- "https://aui-pdf-processing.5c52327048f352f85fb041947c406ab4.r2.cloudflarestorage.com/images/8eb81c61-dc76-48fd-ab66-25cd84a28c97/page-3.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=8698a7e98d990c6edd11fee3a9d0f3f0%2F20250606%2Fauto%2Fs3%2Faws4_request&X-Amz-Date=20250606T035429Z&X-Amz-Expires=3600&X-Amz-Signature=663ee073972f1b7b82cede9039ed4bc0a6c08118533a9586e871807baf032bc2&X-Amz-SignedHeaders=host&x-amz-checksum-mode=ENABLED&x-id=GetObject",
41
- ],
42
- message: "PDF successfully converted to images",
43
- };
44
-
45
- // Mock the API call to return our expected response
46
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
47
-
48
- const requestBody = {
49
- file_url: "https://files.testfile.org/PDF/10MB-TESTFILE.ORG.pdf",
50
- };
51
-
52
- const result = await cloudFiles.pdfToImages(requestBody);
53
-
54
- // Verify the API was called correctly
55
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
56
- method: "POST",
57
- body: requestBody,
58
- });
59
-
60
- // Verify the response structure
61
- expect(result).toEqual(mockResponse);
62
- expect(result.success).toBe(true);
63
- expect(result.urls).toHaveLength(3);
64
- expect(result.message).toBe("PDF successfully converted to images");
65
- expect(result.urls[0]).toContain("page-1.png");
66
- expect(result.urls[1]).toContain("page-2.png");
67
- expect(result.urls[2]).toContain("page-3.png");
68
- });
69
-
70
- /**
71
- * Tests successful PDF to images conversion with file_blob
72
- */
73
- it("should successfully convert PDF to images using file_blob", async () => {
74
- const mockResponse = {
75
- success: true,
76
- urls: [
77
- "https://example.com/converted-image-1.png",
78
- "https://example.com/converted-image-2.png",
79
- ],
80
- message: "PDF successfully converted to images",
81
- };
82
-
83
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
84
-
85
- const requestBody = {
86
- file_blob:
87
- "data:application/pdf;base64,JVBERi0xLjQKJdPr6eEKMSAwIG9iago8PAovVHlwZSAvQ2F0YWxvZwovUGFnZXMgMiAwIFIKPj4KZW5kb2JqCjIgMCBvYmoKPDwKL1R5cGUgL1BhZ2VzCi9LaWRzIFszIDAgUl0KL0NvdW50IDEKL01lZGlhQm94IFswIDAgNTk1IDg0Ml0KPj4KZW5kb2JqCjMgMCBvYmoKPDwKL1R5cGUgL1BhZ2UKL1BhcmVudCAyIDAgUgovTWVkaWFCb3ggWzAgMCA1OTUgODQyXQovQ29udGVudHMgNCAwIFIKPj4KZW5kb2JqCjQgMCBvYmoKPDwKL0xlbmd0aCA0NAo+PgpzdHJlYW0KQlQKL0YxIDEyIFRmCjEwMCA3MDAgVGQKKFRlc3QgUERGKSBUagoKRVQKZW5kc3RyZWFtCmVuZG9iago1IDAgb2JqCjw8Ci9UeXBlIC9Gb250Ci9CYXNlRm9udCAvSGVsdmV0aWNhCi9TdWJ0eXBlIC9UeXBlMQo+PgplbmRvYmoKNiAwIG9iago8PAovVHlwZSAvRm9udERlc2NyaXB0b3IKL0ZvbnROYW1lIC9IZWx2ZXRpY2EKPj4KZW5kb2JqCnhyZWYKMCA3CjAwMDAwMDAwMDAgNjU1MzUgZiAKMDAwMDAwMDAwOSAwMDAwMCBuIAowMDAwMDAwMDc0IDAwMDAwIG4gCjAwMDAwMDAxMzMgMDAwMDAgbiAKMDAwMDAwMDIwNCAwMDAwMCBuIAowMDAwMDAwMjk5IDAwMDAwIG4gCjAwMDAwMDAzNzYgMDAwMDAgbiAKdHJhaWxlcgo8PAovU2l6ZSA3Ci9Sb290IDEgMCBSCj4+CnN0YXJ0eHJlZgo0MzQKJSVFT0YK",
88
- };
89
-
90
- const result = await cloudFiles.pdfToImages(requestBody);
91
-
92
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
93
- method: "POST",
94
- body: requestBody,
95
- });
96
-
97
- expect(result).toEqual(mockResponse);
98
- expect(result.success).toBe(true);
99
- expect(result.urls).toHaveLength(2);
100
- });
101
-
102
- /**
103
- * Tests API error handling
104
- */
105
- it("should handle API errors gracefully", async () => {
106
- const errorMessage = "Invalid PDF file";
107
- vi.mocked(mockApi.makeRequest).mockRejectedValue(new Error(errorMessage));
108
-
109
- const requestBody = {
110
- file_url: "https://invalid-url.com/not-a-pdf.txt",
111
- };
112
-
113
- await expect(cloudFiles.pdfToImages(requestBody)).rejects.toThrow(
114
- errorMessage,
115
- );
116
-
117
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
118
- method: "POST",
119
- body: requestBody,
120
- });
121
- });
122
-
123
- /**
124
- * Tests handling of failed conversion response
125
- */
126
- it("should handle failed conversion response", async () => {
127
- const mockResponse = {
128
- success: false,
129
- urls: [],
130
- message: "Failed to convert PDF: File too large",
131
- };
132
-
133
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
134
-
135
- const requestBody = {
136
- file_url: "https://example.com/huge-file.pdf",
137
- };
138
-
139
- const result = await cloudFiles.pdfToImages(requestBody);
140
-
141
- expect(result.success).toBe(false);
142
- expect(result.urls).toHaveLength(0);
143
- expect(result.message).toBe("Failed to convert PDF: File too large");
144
- });
145
-
146
- /**
147
- * Tests that the method works with both file_url and file_blob undefined (edge case)
148
- */
149
- it("should handle empty request body", async () => {
150
- const mockResponse = {
151
- success: false,
152
- urls: [],
153
- message: "No file provided",
154
- };
155
-
156
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
157
-
158
- const requestBody = {};
159
-
160
- const result = await cloudFiles.pdfToImages(requestBody);
161
-
162
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
163
- method: "POST",
164
- body: requestBody,
165
- });
166
-
167
- expect(result.success).toBe(false);
168
- expect(result.urls).toHaveLength(0);
169
- });
170
-
171
- /**
172
- * Tests that the method sends the correct request headers and structure
173
- * This ensures compatibility with the API key authentication shown in the curl example
174
- */
175
- it("should make request to correct endpoint with proper structure", async () => {
176
- const mockResponse = {
177
- success: true,
178
- urls: ["https://example.com/image.png"],
179
- message: "Success",
180
- };
181
-
182
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
183
-
184
- const requestBody = {
185
- file_url: "https://files.testfile.org/PDF/10MB-TESTFILE.ORG.pdf",
186
- };
187
-
188
- await cloudFiles.pdfToImages(requestBody);
189
-
190
- // Verify the endpoint and method are correct
191
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
192
- method: "POST",
193
- body: requestBody,
194
- });
195
-
196
- // Verify it was called exactly once
197
- expect(mockApi.makeRequest).toHaveBeenCalledTimes(1);
198
- });
199
-
200
- /**
201
- * Tests that both file_url and file_blob can be provided simultaneously
202
- */
203
- it("should handle request with both file_url and file_blob", async () => {
204
- const mockResponse = {
205
- success: true,
206
- urls: ["https://example.com/image.png"],
207
- message: "Success",
208
- };
209
-
210
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
211
-
212
- const requestBody = {
213
- file_url: "https://example.com/file.pdf",
214
- file_blob: "base64data...",
215
- };
216
-
217
- const result = await cloudFiles.pdfToImages(requestBody);
218
-
219
- expect(mockApi.makeRequest).toHaveBeenCalledWith("/files/pdf-to-images", {
220
- method: "POST",
221
- body: requestBody,
222
- });
223
-
224
- expect(result).toEqual(mockResponse);
225
- });
226
- });
227
-
228
- describe("generatePresignedUploadUrl", () => {
229
- /**
230
- * Tests successful generation of presigned upload URL
231
- * This matches the curl request structure provided
232
- */
233
- it("should successfully generate presigned upload URL", async () => {
234
- const mockResponse = {
235
- success: true,
236
- signedUrl:
237
- "https://aui-cloud-attachments.5c52327048f352f85fb041947c406ab4.r2.cloudflarestorage.com/attachments/0204c5a7-cd09-470c-9488-96cf0be9db92.pdf?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=8698a7e98d990c6edd11fee3a9d0f3f0%2F20250606%2Fauto%2Fs3%2Faws4_request&X-Amz-Date=20250606T051813Z&X-Amz-Expires=900&X-Amz-Signature=b0d27e7bee6200eb1964ad1d7f4a8ad76db15a3d99bd4fb47ff4b0b08fee5ca5&X-Amz-SignedHeaders=content-length%3Bhost&x-amz-checksum-crc32=AAAAAA%3D%3D&x-amz-meta-original-filename=hello.pdf&x-amz-meta-project-id=proj_09369w56dnge&x-amz-meta-user-id=676767&x-amz-sdk-checksum-algorithm=CRC32&x-id=PutObject",
238
- expiresAt: "2025-06-06T05:33:13.322Z",
239
- publicUrl:
240
- "https://storage.assistant-api.com/attachments/0204c5a7-cd09-470c-9488-96cf0be9db92.pdf",
241
- };
242
-
243
- // Mock the API call to return our expected response
244
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
245
-
246
- const requestBody = {
247
- filename: "hello.pdf",
248
- };
249
-
250
- const result = await cloudFiles.generatePresignedUploadUrl(requestBody);
251
-
252
- // Verify the API was called correctly
253
- expect(mockApi.makeRequest).toHaveBeenCalledWith(
254
- "/files/attachments/generate-presigned-upload-url",
255
- {
256
- method: "POST",
257
- body: requestBody,
258
- },
259
- );
260
-
261
- // Verify the response structure
262
- expect(result).toEqual(mockResponse);
263
- expect(result.success).toBe(true);
264
- expect(result.signedUrl).toContain("aui-cloud-attachments");
265
- expect(result.signedUrl).toContain("X-Amz-Algorithm=AWS4-HMAC-SHA256");
266
- expect(result.expiresAt).toBe("2025-06-06T05:33:13.322Z");
267
- expect(result.publicUrl).toBe(
268
- "https://storage.assistant-api.com/attachments/0204c5a7-cd09-470c-9488-96cf0be9db92.pdf",
269
- );
270
- });
271
-
272
- /**
273
- * Tests generation with different file types
274
- */
275
- it("should successfully generate presigned upload URL for different file types", async () => {
276
- const mockResponse = {
277
- success: true,
278
- signedUrl:
279
- "https://aui-cloud-attachments.5c52327048f352f85fb041947c406ab4.r2.cloudflarestorage.com/attachments/test-image.png",
280
- expiresAt: "2025-06-06T05:33:13.322Z",
281
- publicUrl:
282
- "https://storage.assistant-api.com/attachments/test-image.png",
283
- };
284
-
285
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
286
-
287
- const requestBody = {
288
- filename: "test-image.png",
289
- };
290
-
291
- const result = await cloudFiles.generatePresignedUploadUrl(requestBody);
292
-
293
- expect(mockApi.makeRequest).toHaveBeenCalledWith(
294
- "/files/attachments/generate-presigned-upload-url",
295
- {
296
- method: "POST",
297
- body: requestBody,
298
- },
299
- );
300
-
301
- expect(result).toEqual(mockResponse);
302
- expect(result.success).toBe(true);
303
- expect(result.publicUrl).toContain("test-image.png");
304
- });
305
-
306
- /**
307
- * Tests API error handling
308
- */
309
- it("should handle API errors gracefully", async () => {
310
- const errorMessage = "Invalid filename";
311
- vi.mocked(mockApi.makeRequest).mockRejectedValue(new Error(errorMessage));
312
-
313
- const requestBody = {
314
- filename: "",
315
- };
316
-
317
- await expect(
318
- cloudFiles.generatePresignedUploadUrl(requestBody),
319
- ).rejects.toThrow(errorMessage);
320
-
321
- expect(mockApi.makeRequest).toHaveBeenCalledWith(
322
- "/files/attachments/generate-presigned-upload-url",
323
- {
324
- method: "POST",
325
- body: requestBody,
326
- },
327
- );
328
- });
329
-
330
- /**
331
- * Tests handling of failed response
332
- */
333
- it("should handle failed upload URL generation response", async () => {
334
- const mockResponse = {
335
- success: false,
336
- signedUrl: "",
337
- expiresAt: "",
338
- publicUrl: "",
339
- };
340
-
341
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
342
-
343
- const requestBody = {
344
- filename: "invalid-file-type.exe",
345
- };
346
-
347
- const result = await cloudFiles.generatePresignedUploadUrl(requestBody);
348
-
349
- expect(result.success).toBe(false);
350
- expect(result.signedUrl).toBe("");
351
- expect(result.publicUrl).toBe("");
352
- });
353
-
354
- /**
355
- * Tests that the method sends the correct request headers and structure
356
- */
357
- it("should make request to correct endpoint with proper structure", async () => {
358
- const mockResponse = {
359
- success: true,
360
- signedUrl: "https://example.com/signed-url",
361
- expiresAt: "2025-06-06T05:33:13.322Z",
362
- publicUrl: "https://example.com/public-url",
363
- };
364
-
365
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
366
-
367
- const requestBody = {
368
- filename: "document.pdf",
369
- };
370
-
371
- await cloudFiles.generatePresignedUploadUrl(requestBody);
372
-
373
- // Verify the endpoint and method are correct
374
- expect(mockApi.makeRequest).toHaveBeenCalledWith(
375
- "/files/attachments/generate-presigned-upload-url",
376
- {
377
- method: "POST",
378
- body: requestBody,
379
- },
380
- );
381
-
382
- // Verify it was called exactly once
383
- expect(mockApi.makeRequest).toHaveBeenCalledTimes(1);
384
- });
385
-
386
- /**
387
- * Tests filename validation scenarios
388
- */
389
- it("should handle various filename formats", async () => {
390
- const mockResponse = {
391
- success: true,
392
- signedUrl: "https://example.com/signed-url",
393
- expiresAt: "2025-06-06T05:33:13.322Z",
394
- publicUrl: "https://example.com/public-url",
395
- };
396
-
397
- vi.mocked(mockApi.makeRequest).mockResolvedValue(mockResponse);
398
-
399
- // Test with filename containing spaces and special characters
400
- const requestBody = {
401
- filename: "my document (final version).pdf",
402
- };
403
-
404
- const result = await cloudFiles.generatePresignedUploadUrl(requestBody);
405
-
406
- expect(mockApi.makeRequest).toHaveBeenCalledWith(
407
- "/files/attachments/generate-presigned-upload-url",
408
- {
409
- method: "POST",
410
- body: requestBody,
411
- },
412
- );
413
-
414
- expect(result).toEqual(mockResponse);
415
- });
416
- });
417
-
418
- // Integration test that actually calls the real API
419
- describe("Integration Tests", () => {
420
- /**
421
- * Integration test that actually calls the real API endpoint
422
- * This test requires real API credentials to be set in environment variables:
423
- * - AUI_API_KEY: Your API key (e.g., sk_aui_proj_...)
424
- * - AUI_USER_ID: Your user ID
425
- * - AUI_WORKSPACE_ID: Your workspace ID
426
- */
427
- it.skipIf(
428
- !process.env.AUI_API_KEY ||
429
- !process.env.AUI_USER_ID ||
430
- !process.env.AUI_WORKSPACE_ID,
431
- )(
432
- "should actually convert PDF to images using real API",
433
- async () => {
434
- // Unmock all modules for this test to use real implementations
435
- vi.doUnmock("../cloud/AssistantCloudAPI");
436
- vi.doUnmock("../cloud/AssistantCloudFiles");
437
- vi.doUnmock("../cloud/AssistantCloud");
438
-
439
- // Clear all mocks and reload modules
440
- vi.resetModules();
441
-
442
- // Import real modules
443
- const { AssistantCloud: RealAssistantCloud } = await import(
444
- "../cloud/AssistantCloud"
445
- );
446
-
447
- const realCloud = new RealAssistantCloud({
448
- apiKey: process.env.AUI_API_KEY!,
449
- userId: process.env.AUI_USER_ID!,
450
- workspaceId: process.env.AUI_WORKSPACE_ID!,
451
- });
452
-
453
- const requestBody = {
454
- file_url: "https://files.testfile.org/PDF/10MB-TESTFILE.ORG.pdf",
455
- };
456
-
457
- console.log("Making API call to convert PDF...");
458
- const result = await realCloud.files.pdfToImages(requestBody);
459
- console.log("API call result:", result);
460
-
461
- // Verify the response structure
462
- expect(result).toHaveProperty("success");
463
- expect(result).toHaveProperty("urls");
464
- expect(result).toHaveProperty("message");
465
-
466
- if (result.success) {
467
- expect(Array.isArray(result.urls)).toBe(true);
468
- expect(result.urls.length).toBeGreaterThan(0);
469
- expect(typeof result.message).toBe("string");
470
-
471
- // Verify URLs are valid image URLs
472
- result.urls.forEach((url) => {
473
- expect(url).toMatch(/^https:\/\/.+\.(png|jpg|jpeg)(\?.*)?$/i);
474
- });
475
- } else {
476
- // If it fails, at least verify the error message is a string
477
- expect(typeof result.message).toBe("string");
478
- console.log("API call failed:", result.message);
479
- }
480
-
481
- // Restore mocks after the test
482
- vi.doMock("../cloud/AssistantCloudAPI");
483
- },
484
- 60000, // 60 second timeout for real API calls
485
- );
486
-
487
- /**
488
- * Integration test for generatePresignedUploadUrl that actually calls the real API endpoint
489
- * This test requires real API credentials to be set in environment variables:
490
- * - AUI_API_KEY: Your API key (e.g., sk_aui_proj_...)
491
- * - AUI_USER_ID: Your user ID
492
- * - AUI_WORKSPACE_ID: Your workspace ID
493
- */
494
- it.skipIf(
495
- !process.env.AUI_API_KEY ||
496
- !process.env.AUI_USER_ID ||
497
- !process.env.AUI_WORKSPACE_ID,
498
- )(
499
- "should actually generate presigned upload URL using real API",
500
- async () => {
501
- // Unmock all modules for this test to use real implementations
502
- vi.doUnmock("../cloud/AssistantCloudAPI");
503
- vi.doUnmock("../cloud/AssistantCloudFiles");
504
- vi.doUnmock("../cloud/AssistantCloud");
505
-
506
- // Clear all mocks and reload modules
507
- vi.resetModules();
508
-
509
- // Import real modules
510
- const { AssistantCloud: RealAssistantCloud } = await import(
511
- "../cloud/AssistantCloud"
512
- );
513
-
514
- const realCloud = new RealAssistantCloud({
515
- apiKey: process.env.AUI_API_KEY!,
516
- userId: process.env.AUI_USER_ID!,
517
- workspaceId: process.env.AUI_WORKSPACE_ID!,
518
- });
519
-
520
- const requestBody = {
521
- filename: "test-upload.pdf",
522
- };
523
-
524
- console.log("Making API call to generate presigned upload URL...");
525
- const result =
526
- await realCloud.files.generatePresignedUploadUrl(requestBody);
527
- console.log("API call result:", result);
528
-
529
- // Verify the response structure
530
- expect(result).toHaveProperty("success");
531
- expect(result).toHaveProperty("signedUrl");
532
- expect(result).toHaveProperty("expiresAt");
533
- expect(result).toHaveProperty("publicUrl");
534
-
535
- if (result.success) {
536
- expect(typeof result.signedUrl).toBe("string");
537
- expect(typeof result.expiresAt).toBe("string");
538
- expect(typeof result.publicUrl).toBe("string");
539
- expect(result.signedUrl.length).toBeGreaterThan(0);
540
- expect(result.publicUrl.length).toBeGreaterThan(0);
541
-
542
- // Verify URLs are valid HTTPS URLs
543
- expect(result.signedUrl).toMatch(/^https:\/\/.+/);
544
- expect(result.publicUrl).toMatch(/^https:\/\/.+/);
545
-
546
- // Verify the signed URL contains expected AWS signature parameters
547
- expect(result.signedUrl).toContain("X-Amz-Algorithm");
548
- expect(result.signedUrl).toContain("X-Amz-Signature");
549
-
550
- // Verify expiresAt is a valid ISO date string
551
- expect(() => new Date(result.expiresAt)).not.toThrow();
552
- } else {
553
- console.log(
554
- "API call failed - this may be expected for some test cases",
555
- );
556
- }
557
-
558
- // Restore mocks after the test
559
- vi.doMock("../cloud/AssistantCloudAPI");
560
- },
561
- 30000, // 30 second timeout for real API calls
562
- );
563
- });
564
- });