roksta 0.2.4__cp314-cp314-macosx_10_13_universal2.whl → 0.2.6__cp314-cp314-macosx_10_13_universal2.whl

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.

Potentially problematic release.


This version of roksta might be problematic. Click here for more details.

Files changed (54) hide show
  1. roksta/ai/gemini.cpython-314-darwin.so +0 -0
  2. roksta/ai/generic.cpython-314-darwin.so +0 -0
  3. roksta/ai/llm.cpython-314-darwin.so +0 -0
  4. roksta/ai/openai.cpython-314-darwin.so +0 -0
  5. roksta/ai/tools.cpython-314-darwin.so +0 -0
  6. roksta/analytics.cpython-314-darwin.so +0 -0
  7. roksta/chat_workflow.cpython-314-darwin.so +0 -0
  8. roksta/command_handlers.cpython-314-darwin.so +0 -0
  9. roksta/env.cpython-314-darwin.so +0 -0
  10. roksta/extended_text_area.cpython-314-darwin.so +0 -0
  11. roksta/firebase_auth_web.cpython-314-darwin.so +0 -0
  12. roksta/gen_codebase_summaries.cpython-314-darwin.so +0 -0
  13. roksta/goal_workflow.cpython-314-darwin.so +0 -0
  14. roksta/lint_code.cpython-314-darwin.so +0 -0
  15. roksta/main.cpython-314-darwin.so +0 -0
  16. roksta/make_issue.cpython-314-darwin.so +0 -0
  17. roksta/new_features.cpython-314-darwin.so +0 -0
  18. roksta/parse_readme.cpython-314-darwin.so +0 -0
  19. roksta/roksta.cpython-314-darwin.so +0 -0
  20. roksta/run_cli_goal.cpython-314-darwin.so +0 -0
  21. roksta/tips.cpython-314-darwin.so +0 -0
  22. roksta/utils.cpython-314-darwin.so +0 -0
  23. {roksta-0.2.4.dist-info → roksta-0.2.6.dist-info}/METADATA +1 -1
  24. roksta-0.2.6.dist-info/RECORD +78 -0
  25. {roksta-0.2.4.dist-info → roksta-0.2.6.dist-info}/top_level.txt +1 -0
  26. tests/__init__.py +2 -0
  27. tests/conftest.py +169 -0
  28. tests/functions/__init__.py +2 -0
  29. tests/functions/api_v0_01/__init__.py +2 -0
  30. tests/functions/api_v0_01/test__analytics.py +417 -0
  31. tests/functions/api_v0_01/test__gemini_proxy.py +307 -0
  32. tests/functions/api_v0_01/test__generic_proxy.py +399 -0
  33. tests/functions/api_v0_01/test__get_payment_details.py +356 -0
  34. tests/functions/api_v0_01/test__openai_proxy.py +413 -0
  35. tests/functions/api_v0_01/test__redeem_credit_code.py +167 -0
  36. tests/functions/api_v0_01/test__sync_emails.py +324 -0
  37. tests/functions/api_v0_01/test__take_payment.py +491 -0
  38. tests/functions/api_v0_01/test__use_activation_code.py +437 -0
  39. tests/functions/api_v1_00/__init__.py +2 -0
  40. tests/functions/api_v1_00/test__analytics.py +416 -0
  41. tests/functions/api_v1_00/test__gemini_proxy.py +352 -0
  42. tests/functions/api_v1_00/test__generic_proxy.py +428 -0
  43. tests/functions/api_v1_00/test__get_payment_details.py +356 -0
  44. tests/functions/api_v1_00/test__openai_proxy.py +449 -0
  45. tests/functions/api_v1_00/test__redeem_credit_code.py +167 -0
  46. tests/functions/api_v1_00/test__sync_emails.py +325 -0
  47. tests/functions/api_v1_00/test__take_payment.py +491 -0
  48. tests/functions/api_v1_00/test__use_activation_code.py +438 -0
  49. tests/functions/test_auth.py +24 -0
  50. tests/functions/test_main_functions.py +73 -0
  51. tests/functions/test_utils_functions.py +222 -0
  52. roksta-0.2.4.dist-info/RECORD +0 -51
  53. {roksta-0.2.4.dist-info → roksta-0.2.6.dist-info}/WHEEL +0 -0
  54. {roksta-0.2.4.dist-info → roksta-0.2.6.dist-info}/entry_points.txt +0 -0
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: roksta
3
- Version: 0.2.4
3
+ Version: 0.2.6
4
4
  Summary: An AI coding assistant
5
5
  Author-email: Prash Naidu <prash@roksta.ai>
6
6
  Project-URL: Homepage, https://roksta.ai
@@ -0,0 +1,78 @@
1
+ roksta-0.2.6.dist-info/RECORD,,
2
+ roksta-0.2.6.dist-info/WHEEL,sha256=kTyoa6dywfGfyBeUsEKMOPsM0w-CaDJ_dSETLrKd4uk,142
3
+ roksta-0.2.6.dist-info/entry_points.txt,sha256=mzRdYg_DlzZRwjxYUt9-gyoRCkM1QBTeTbwETgiTdGw,44
4
+ roksta-0.2.6.dist-info/top_level.txt,sha256=lvciNZQ1dPGXpiCLdWVXK03n9fKHjbQdwjqQbnUjeYM,13
5
+ roksta-0.2.6.dist-info/METADATA,sha256=gBXNX4iwCT9vychi5wNnmihf7ptAXoiAymfGKYchiNo,1427
6
+ roksta/balance.cpython-314-darwin.so,sha256=Fk1LS4rVuruNwjcKV4pawpa9kTx3FWNHGEmsK9cNAWA,340432
7
+ roksta/propose_solution.cpython-314-darwin.so,sha256=Wubg-p21XHZ5NLvvQUzCNkxGnyGq_EwUQUv4WaTWOyM,207496
8
+ roksta/gen_codebase_summaries.cpython-314-darwin.so,sha256=IBeUeRqccCV_D39rsktPcvIKkpiR-7mzxuG9spCaRsw,637936
9
+ roksta/codebase_listing.cpython-314-darwin.so,sha256=Kxtkn9xa9WOqLXUXrLw_3vGP6VJsfXWe_db-D0EWiLA,155608
10
+ roksta/__init__.cpython-314-darwin.so,sha256=EL2fuUK0drBv_kRWrblymcUCrc8PcfoFZkxUTWRE4cE,85648
11
+ roksta/default_config.cpython-314-darwin.so,sha256=TC5tHkaMXczwS0jYK7veAzvTFneBt7VPYqd9GaRn1Uw,102248
12
+ roksta/create_default_config.cpython-314-darwin.so,sha256=bMeI3fxxRJQ0IJmhtotbYkkUMZun7ymFaa9BmVeYu1M,121608
13
+ roksta/make_issue.cpython-314-darwin.so,sha256=NyqUA_THUg1R3iBGLeZhFQVTVw9fS9tDwTF9P7RoIgk,221856
14
+ roksta/firebase_auth_web.cpython-314-darwin.so,sha256=uZSGuAUadl1JhHMin_UiVNe7NfLsE-4UQvNgybCQWxo,489048
15
+ roksta/fix_tests.cpython-314-darwin.so,sha256=g27HScuadiggXvgdBJlwFIBHz1Qqx3yNbZi67YTemxY,240704
16
+ roksta/get_failing_tests.cpython-314-darwin.so,sha256=tZyV_x70kDu92_4gwlACDyAxY2vsEMRJ0XoFuBwSOGQ,224296
17
+ roksta/env.cpython-314-darwin.so,sha256=18E4wTcHZhyVuhmuyxRaiol8tNeA8CMlx9pjktFUb30,87832
18
+ roksta/roksta.cpython-314-darwin.so,sha256=kI9sTFkuJQHanJV-pFpRjia-sRX8RVZarV3SPYVNsio,588128
19
+ roksta/clarify_goal.cpython-314-darwin.so,sha256=jy2iw0fv86k6y7J-nGVm3JAaSHRnU74tnCS0FMRkrbQ,207808
20
+ roksta/run_cli_goal.cpython-314-darwin.so,sha256=l1mTdfSfJwCESJS3RgxVsylTe3zTr_E6PTrudP1yf_o,223968
21
+ roksta/rewrite_goal.cpython-314-darwin.so,sha256=kUrDcnDo0NPmeoG2sFiEVAKhmTnCqk7PJGktyCrzmCg,191072
22
+ roksta/build_project.cpython-314-darwin.so,sha256=SHRxDasBlCqsqQrh4gs45ZMTa5q5WK-rZnvdjIQtYvU,191184
23
+ roksta/analytics.cpython-314-darwin.so,sha256=zsP32jnFDlB_O0RUPmsFV8ajEexRMAJEgFuQUSmJmY4,289680
24
+ roksta/command_handlers.cpython-314-darwin.so,sha256=La_oUhxiNPXrl8fNXi_8tzoUzbWBskT9Jxw8SLBSPv8,966584
25
+ roksta/main.cpython-314-darwin.so,sha256=W3NXMp8keVb_i1gK4R9lAg4pTdVpnu6_HYblY4meYZ0,122184
26
+ roksta/utils.cpython-314-darwin.so,sha256=cgeW3SKvZh3nXwHVDvM9iD-EMHNA_dOI9yZic3fZSeM,589128
27
+ roksta/check_for_updates.cpython-314-darwin.so,sha256=-aVFV7CiOakaWutOOqGb2Po_E1qFYTAjYWTu9uorjKM,206904
28
+ roksta/response_formats.cpython-314-darwin.so,sha256=yLrtRaRY87oQrwk_KHlKbYJxxxwcCmp7sGXLByj8j7I,120968
29
+ roksta/select_files.cpython-314-darwin.so,sha256=D2MxqKwSUQDKeSamsAgj2moxwEsBu54N40OQS7DYQks,207792
30
+ roksta/goal_workflow.cpython-314-darwin.so,sha256=ttaW0GZJsjayOogc8deCoEzzTsNzC7Lfo6QyJt3vjiw,521008
31
+ roksta/parse_readme.cpython-314-darwin.so,sha256=VVKOmQO5Rx9AmvwiYyuHqaS4YZgzF4IdUb5YmwoxFqA,207280
32
+ roksta/firebase.cpython-314-darwin.so,sha256=88qE-bZ03ssH1uAA4P6SV-bIZlFvPbAYYWK8tDJjvX0,471792
33
+ roksta/write_code.cpython-314-darwin.so,sha256=19cEofGYSpK4lz1bwzGmTkS8kTxjE1HF4WiZzX8OtnM,191152
34
+ roksta/enums.cpython-314-darwin.so,sha256=LAFSg6tcRyejdBY1ILo9wy1wXy_ShiE31jyF_9L6k90,338344
35
+ roksta/tips.cpython-314-darwin.so,sha256=wJwFDKsOGVPHrbfNfXK6XTb6nu6gmd3Y2rS1vCF1w-8,85688
36
+ roksta/firebase_config.cpython-314-darwin.so,sha256=odBL74t5UEMoLoOFJK1rmXTnSbXjNpMIEIO6AU6cycY,86328
37
+ roksta/gen_one_line_goal.cpython-314-darwin.so,sha256=zs5gGHfaeXPPvg6OuvXhD-nRBwpYc4_eUEmrBK8UCUI,207768
38
+ roksta/new_features.cpython-314-darwin.so,sha256=TO9FNiM3NadDYXsQAbO4Q7SGRk9JkSU-CzwOfRW7nQA,85728
39
+ roksta/init_codebase.cpython-314-darwin.so,sha256=Pvzno5CdiS6OoHhOmQ1GtHvaXGqH1vU9qBofiOW8-rA,308208
40
+ roksta/chat_workflow.cpython-314-darwin.so,sha256=B6Sp8vQOZM0paNYVuEgMkYm3_lDTGtTn0eXKOXkg7V0,273888
41
+ roksta/lint_code.cpython-314-darwin.so,sha256=1N1-eXF8fHrJfplMj0cXgj0_xzAErze6SQ-tpufSqDI,208048
42
+ roksta/get_codebase_structure.cpython-314-darwin.so,sha256=d3u3L9M9Q3DMhivR98L3PkS21kFb4gcGmbqfOAY9gRo,206240
43
+ roksta/checkpoints.cpython-314-darwin.so,sha256=QJ2smLnbWBmVpUtl0Kdlq0Bvl1Av7fa7lp3kxdseEJc,254320
44
+ roksta/extended_text_area.cpython-314-darwin.so,sha256=U-nPzf38_zyB5zcJOvoc5cgf0cSZU8hBbisC40pyYoI,290824
45
+ roksta/logger.cpython-314-darwin.so,sha256=10IAF2iGigOpOjYYce5yT3brfc8GxOjGpSKLn4XVeJM,122032
46
+ roksta/ai/__init__.cpython-314-darwin.so,sha256=BaV83jdQCG8M2_8ycpRBHVWX-QcoeQt2yq-HyFIGnYI,85648
47
+ roksta/ai/generic.cpython-314-darwin.so,sha256=0UJ-foXBtB1QCJkFHxrXf9CapUedTpd722bLeNnhblA,306944
48
+ roksta/ai/gemini.cpython-314-darwin.so,sha256=0UdPYE-6aWLfUxoBUGct7i7cHdecgo_AlMQIDPF-XGM,422608
49
+ roksta/ai/call_ai.cpython-314-darwin.so,sha256=P9obp-3vEqzPpMHG4CKQIPR9bjm8a02n5VUz0-mWLuI,240768
50
+ roksta/ai/llm.cpython-314-darwin.so,sha256=a9OORYZXZS0wn8mdhuDmQMBzOr-tumHc1UYhyVzp7_w,271496
51
+ roksta/ai/tools.cpython-314-darwin.so,sha256=EFGdl2fU6SfI0MGd81EKst8EiDuFVEpzegWr4LQ3kyU,653976
52
+ roksta/ai/openai.cpython-314-darwin.so,sha256=nhZ4YeH6knV937kO-LVM5x5rHTr6WB19I02ScHa_CiU,306928
53
+ tests/conftest.py,sha256=WBja46X2wduZRF2t4LARhbNvLlU8oRhSW_HB6ara8Yg,6295
54
+ tests/__init__.py,sha256=J6ztnXNqM8TSQCgHXMWb6NRq1kN_h4ql63Jq-TYR8XE,124
55
+ tests/functions/test_auth.py,sha256=I3oFTw2LTuUsnQ75v5SCfgUPnpel_pDKqUH0VAJpXQw,992
56
+ tests/functions/__init__.py,sha256=mLXx3UARcv07vs_fGJuy3L5ZRn9IRsF9zIuL5IOnwdk,95
57
+ tests/functions/test_utils_functions.py,sha256=gS-SxnK0QnVUooxcXlJKodjqOB1HVmUxufwzUPQ7qAk,7368
58
+ tests/functions/test_main_functions.py,sha256=h0W_4ISo95WzRy2HpXZw3cuNOTcYk_2QCIZffZJEfEU,2575
59
+ tests/functions/api_v1_00/test__sync_emails.py,sha256=OTyf2YbBK7e4pWIQTUGYR4x6il1Hb3g4FYqQ_fRj1nA,12699
60
+ tests/functions/api_v1_00/test__take_payment.py,sha256=I-XJasGuLW5wTMAu4nAgFkA8Mo_zVpGPvkJ2LrrJGCk,18022
61
+ tests/functions/api_v1_00/test__gemini_proxy.py,sha256=mf8ubRmNxxxN80H6EA-iDPwu6Oue6Rmgxl6tiFNpfrU,13344
62
+ tests/functions/api_v1_00/test__analytics.py,sha256=oKjd7_zjnttcb-5BuA93yllkm0OOF4YWnfTUW1-icnM,15806
63
+ tests/functions/api_v1_00/__init__.py,sha256=3RCSoj_5UQPw9Z5NeAgYz2s4gfcZIi7g36qk_Ed5TiA,124
64
+ tests/functions/api_v1_00/test__use_activation_code.py,sha256=tNyTkkRtrpjei-7F31UNwrcU-PbP-QnkWNU7h2n5Yqo,16960
65
+ tests/functions/api_v1_00/test__redeem_credit_code.py,sha256=7GD3tGgO2Lk0BCjUmzZACJiwocEhLBvXrrut0x13IWU,6347
66
+ tests/functions/api_v1_00/test__openai_proxy.py,sha256=xlO2zmG64LlrKrbjFz-ds6Map7vy4SjIuHfZJDAqGK8,17726
67
+ tests/functions/api_v1_00/test__get_payment_details.py,sha256=i5Px3NkLxqw8D3tVPrYdRJJF5jlNmysSuX_NNolbIa4,13735
68
+ tests/functions/api_v1_00/test__generic_proxy.py,sha256=KZkOtmc71aOnWlz2L7B6CFhRNEV73bExG3GR14oD2L0,17673
69
+ tests/functions/api_v0_01/test__sync_emails.py,sha256=zCfuh1M6qJlGaCpCWuUE0Ao9Pp5pVkBJXXjoctldkpk,12698
70
+ tests/functions/api_v0_01/test__take_payment.py,sha256=2WDv_7cYTozVMl7hDLNDTF9gmfrgna3oR8xgfRa-plA,18022
71
+ tests/functions/api_v0_01/test__gemini_proxy.py,sha256=R-lzyVsNtqJFGILKhgy1cUIHg1SYPSFKNDbKp2fua-k,11152
72
+ tests/functions/api_v0_01/test__analytics.py,sha256=nMs_aYuXDEFWz9aY21MYwbgugF-czRbucAzis4-8kgc,15807
73
+ tests/functions/api_v0_01/__init__.py,sha256=BOIFrFcANRAbpnX0Bez6rtkj6xJnOli1fqzFX5SpkV0,124
74
+ tests/functions/api_v0_01/test__use_activation_code.py,sha256=EgifjM9wkW1fkQoBK9z5PEEM5xwpRHyt_g7QWy6xrec,16959
75
+ tests/functions/api_v0_01/test__redeem_credit_code.py,sha256=WSs7CE2pkHsied_tg3XCR3RJ9blwQEkOzy-s3lkV_w0,6347
76
+ tests/functions/api_v0_01/test__openai_proxy.py,sha256=Nda-RDUVYBQl2wI5mxxr9Ca-9k9HJV5EgEmdIvyytGs,15761
77
+ tests/functions/api_v0_01/test__get_payment_details.py,sha256=3LYAp9m1RDsf928HGJ6P_YTji7F4srkDv0iWcKTwW54,13735
78
+ tests/functions/api_v0_01/test__generic_proxy.py,sha256=cJftek6njsphK_yesUX1QxphGcD5TEkhQNC5ROvnaIg,16190
tests/__init__.py ADDED
@@ -0,0 +1,2 @@
1
+ # tests package marker
2
+ # This file allows pytest to import tests using package-qualified names, avoiding import collisions.
tests/conftest.py ADDED
@@ -0,0 +1,169 @@
1
+ import os
2
+ import sys
3
+ import importlib
4
+ import types as _types_mod
5
+
6
+ # Ensure local package is imported before any globally installed packages.
7
+ sys.path.insert(0, os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))
8
+
9
+ # Ensure functions directory is on sys.path so top-level function helpers (e.g. 'utils')
10
+ # can be imported by tests after the functions/ reorganisation.
11
+ _functions_root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', 'functions'))
12
+ if _functions_root not in sys.path:
13
+ sys.path.insert(0, _functions_root)
14
+
15
+ # Ensure functions/api_v0_01 (or a compatible API directory) is on sys.path so tests that import top-level function
16
+ # modules (e.g. '_analytics') can still find them after the functions/ reorganisation.
17
+ _api_candidates = ['api_v0_01', 'api_v001', 'api_v0_1', 'api_v01']
18
+ _functions_api_dir = None
19
+ for candidate in _api_candidates:
20
+ candidate_path = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', 'functions', candidate))
21
+ if os.path.isdir(candidate_path):
22
+ _functions_api_dir = candidate_path
23
+ break
24
+ if _functions_api_dir and _functions_api_dir not in sys.path:
25
+ sys.path.insert(0, _functions_api_dir)
26
+
27
+ # Provide a minimal google.genai.types stub if the real package is not available.
28
+ # This avoids import-time errors in tests that import modules which reference
29
+ # google.genai.types at import time. The stub is intentionally lightweight and
30
+ # only implements the attributes needed for import and simple spec-based mocks
31
+ # used in the test-suite. Individual tests may still override these with more
32
+ # detailed fakes when required.
33
+
34
+
35
+ def _attach_gtypes_stubs(gtypes_mod):
36
+ """
37
+ Attach minimal placeholder implementations to the provided module object.
38
+ Only attaches attributes that are missing on the module to avoid clobbering
39
+ a real installed package.
40
+ """
41
+ # Minimal placeholder implementations
42
+ class GenerateContentConfig:
43
+ def __init__(self, **kwargs):
44
+ self.__dict__.update(kwargs)
45
+ self.kwargs = kwargs
46
+ def to_json_dict(self):
47
+ return dict(self.kwargs)
48
+
49
+ class ThinkingConfig:
50
+ def __init__(self, thinking_budget=None):
51
+ self.thinking_budget = thinking_budget
52
+
53
+ class AutomaticFunctionCallingConfig:
54
+ def __init__(self, disable=False):
55
+ self.disable = disable
56
+
57
+ class GoogleSearch:
58
+ def __init__(self):
59
+ pass
60
+
61
+ class Tool:
62
+ def __init__(self, **kwargs):
63
+ self.kwargs = kwargs
64
+
65
+ class UsageMetadata:
66
+ def __init__(self, prompt_token_count=0, total_token_count=0):
67
+ self.prompt_token_count = prompt_token_count
68
+ self.total_token_count = total_token_count
69
+
70
+ class FinishReasonEnum:
71
+ def __init__(self, name='FINISH_REASON_UNSPECIFIED'):
72
+ self.name = name
73
+
74
+ class FinishReason:
75
+ FINISH_REASON_UNSPECIFIED = FinishReasonEnum('FINISH_REASON_UNSPECIFIED')
76
+
77
+ class Part:
78
+ def __init__(self, text=None, function_call=None):
79
+ self.text = text
80
+ self.function_call = function_call
81
+
82
+ @classmethod
83
+ def from_function_response(cls, name=None, response=None):
84
+ inst = cls()
85
+ inst.function_response = _types_mod.SimpleNamespace(name=name, response=response)
86
+ return inst
87
+
88
+ class Content:
89
+ def __init__(self, role=None, parts=None):
90
+ self.role = role
91
+ self.parts = parts or []
92
+
93
+ def model_dump(self, mode='json'):
94
+ return {'role': self.role, 'parts': [getattr(p, 'text', p) for p in self.parts]}
95
+
96
+ class FunctionCall:
97
+ def __init__(self, name=None, args=None):
98
+ self.name = name
99
+ self.args = args
100
+
101
+ class Candidate:
102
+ def __init__(self, content=None, finish_reason=None):
103
+ self.content = content
104
+ self.finish_reason = finish_reason
105
+
106
+ class GenerateContentResponse:
107
+ def __init__(self, **kwargs):
108
+ for k, v in kwargs.items():
109
+ setattr(self, k, v)
110
+ # sensible defaults
111
+ if not hasattr(self, 'text'):
112
+ self.text = ''
113
+ if not hasattr(self, 'candidates'):
114
+ self.candidates = []
115
+ if not hasattr(self, 'usage_metadata'):
116
+ self.usage_metadata = None
117
+
118
+ def to_json_dict(self):
119
+ return {k: getattr(self, k) for k in self.__dict__}
120
+
121
+ stubs = {
122
+ 'GenerateContentConfig': GenerateContentConfig,
123
+ 'ThinkingConfig': ThinkingConfig,
124
+ 'AutomaticFunctionCallingConfig': AutomaticFunctionCallingConfig,
125
+ 'GoogleSearch': GoogleSearch,
126
+ 'Tool': Tool,
127
+ 'UsageMetadata': UsageMetadata,
128
+ 'FinishReason': FinishReason,
129
+ 'Part': Part,
130
+ 'Content': Content,
131
+ 'FunctionCall': FunctionCall,
132
+ 'Candidate': Candidate,
133
+ 'GenerateContentResponse': GenerateContentResponse,
134
+ }
135
+
136
+ for name, obj in stubs.items():
137
+ if not hasattr(gtypes_mod, name):
138
+ setattr(gtypes_mod, name, obj)
139
+
140
+
141
+ # Try to import the real google.genai.types module. If it exists, only patch in
142
+ # any missing attributes. If it doesn't exist, create minimal stub modules and
143
+ # register them on sys.modules so imports like `from google.genai import types`
144
+ # work during the tests.
145
+ try:
146
+ gtypes = importlib.import_module('google.genai.types')
147
+ _attach_gtypes_stubs(gtypes)
148
+ except Exception:
149
+ # Ensure top-level `google` module exists in sys.modules, but do not overwrite
150
+ # a real `google` module if it is already installed.
151
+ try:
152
+ google = importlib.import_module('google')
153
+ except Exception:
154
+ google = _types_mod.ModuleType('google')
155
+ sys.modules['google'] = google
156
+
157
+ # Ensure `google.genai` exists; prefer the real module if present.
158
+ try:
159
+ genai = importlib.import_module('google.genai')
160
+ except Exception:
161
+ genai = _types_mod.ModuleType('google.genai')
162
+ sys.modules['google.genai'] = genai
163
+ setattr(google, 'genai', genai)
164
+
165
+ # Create and attach the minimal `google.genai.types` stub
166
+ gtypes = _types_mod.ModuleType('google.genai.types')
167
+ _attach_gtypes_stubs(gtypes)
168
+ genai.types = gtypes
169
+ sys.modules['google.genai.types'] = gtypes
@@ -0,0 +1,2 @@
1
+ # tests.functions package marker
2
+ # Ensures subtests are imported as package-qualified modules.
@@ -0,0 +1,2 @@
1
+ # tests.functions.api_v0_01 package marker
2
+ # Allows tests under this directory to be imported with package-qualified names.