qbraid-cli 0.10.6__tar.gz → 0.10.8__tar.gz

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 qbraid-cli might be problematic. Click here for more details.

Files changed (125) hide show
  1. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/bump-version.yml +2 -2
  2. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/ci-pr-target.yml +6 -6
  3. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/docs-pr.yml +4 -4
  4. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/docs.yml +2 -2
  5. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/format.yml +2 -2
  6. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/main.yml +6 -6
  7. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/pre-release.yml +2 -2
  8. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/publish.yml +2 -2
  9. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/workflows/tag-on-merge.yml +1 -1
  10. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/PKG-INFO +2 -2
  11. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/requirements.txt +1 -1
  12. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/pyproject.toml +2 -2
  13. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/account/app.py +3 -1
  14. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/configure/actions.py +13 -6
  15. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/devices/app.py +25 -2
  16. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/envs/app.py +1 -0
  17. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/files/app.py +2 -2
  18. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/handlers.py +16 -0
  19. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/jobs/app.py +22 -5
  20. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/PKG-INFO +2 -2
  21. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/SOURCES.txt +2 -1
  22. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/requires.txt +1 -1
  23. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/account/test_account_credits.py +0 -2
  24. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/configure/test_configure_commands.py +26 -2
  25. qbraid_cli-0.10.8/tests/configure/test_configure_default.py +61 -0
  26. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/configure/test_configure_prompt_for_config.py +1 -3
  27. qbraid_cli-0.10.8/tests/devices/test_devices_get.py +278 -0
  28. qbraid_cli-0.10.8/tests/jobs/test_jobs_get.py +179 -0
  29. qbraid_cli-0.10.6/qbraid_cli/_version.py +0 -21
  30. qbraid_cli-0.10.6/tests/configure/test_configure_default.py +0 -54
  31. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.env.example +0 -0
  32. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/ISSUE_TEMPLATE/bug_report.yml +0 -0
  33. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/ISSUE_TEMPLATE/feature_request.yml +0 -0
  34. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/PULL_REQUEST_TEMPLATE.md +0 -0
  35. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.github/dependabot.yml +0 -0
  36. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.gitignore +0 -0
  37. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/.readthedocs.yml +0 -0
  38. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/CONTRIBUTING.md +0 -0
  39. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/LICENSE +0 -0
  40. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/MANIFEST.IN +0 -0
  41. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/Makefile +0 -0
  42. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/README.md +0 -0
  43. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/Makefile +0 -0
  44. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/_static/favicon.ico +0 -0
  45. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/_static/logo.png +0 -0
  46. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/_static/style/custom.css +0 -0
  47. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/_static/style/s4defs-roles.css +0 -0
  48. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/conf.py +0 -0
  49. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/index.rst +0 -0
  50. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/docs/make.bat +0 -0
  51. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/__init__.py +0 -0
  52. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/account/__init__.py +0 -0
  53. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/admin/__init__.py +0 -0
  54. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/admin/app.py +0 -0
  55. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/admin/headers.py +0 -0
  56. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/admin/validation.py +0 -0
  57. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/chat/__init__.py +0 -0
  58. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/chat/app.py +0 -0
  59. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/configure/__init__.py +0 -0
  60. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/configure/app.py +0 -0
  61. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/devices/__init__.py +0 -0
  62. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/devices/validation.py +0 -0
  63. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/envs/__init__.py +0 -0
  64. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/envs/activate.py +0 -0
  65. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/envs/create.py +0 -0
  66. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/envs/data_handling.py +0 -0
  67. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/exceptions.py +0 -0
  68. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/files/__init__.py +0 -0
  69. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/jobs/__init__.py +0 -0
  70. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/jobs/toggle_braket.py +0 -0
  71. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/jobs/validation.py +0 -0
  72. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/kernels/__init__.py +0 -0
  73. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/kernels/app.py +0 -0
  74. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/main.py +0 -0
  75. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/pip/__init__.py +0 -0
  76. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/pip/app.py +0 -0
  77. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/pip/hooks.py +0 -0
  78. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli/py.typed +0 -0
  79. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/dependency_links.txt +0 -0
  80. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/entry_points.txt +0 -0
  81. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/qbraid_cli.egg-info/top_level.txt +0 -0
  82. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/setup.cfg +0 -0
  83. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/__init__.py +0 -0
  84. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/account/__init__.py +0 -0
  85. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/admin/test_headers.py +0 -0
  86. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/configure/__init__.py +0 -0
  87. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/configure/test_configure_set.py +0 -0
  88. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/configure/test_configure_validate_input.py +0 -0
  89. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/conftest.py +0 -0
  90. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/devices/__init__.py +0 -0
  91. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/devices/test_devices_list.py +0 -0
  92. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/devices/test_devices_validations.py +0 -0
  93. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/__init__.py +0 -0
  94. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_activate.py +0 -0
  95. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_activate_find_shell_rc.py +0 -0
  96. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_activate_print_command.py +0 -0
  97. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_activate_pyenv.py +0 -0
  98. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_create_from_yaml.py +0 -0
  99. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_list.py +0 -0
  100. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/envs/test_envs_remove.py +0 -0
  101. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/files/__init__.py +0 -0
  102. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/files/test_files_commands.py +0 -0
  103. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/__init__.py +0 -0
  104. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_disable.py +0 -0
  105. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_enable.py +0 -0
  106. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_list.py +0 -0
  107. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_state.py +0 -0
  108. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_toggle_braket_confirm.py +0 -0
  109. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_toggle_braket_disable.py +0 -0
  110. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_toggle_braket_enable.py +0 -0
  111. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_toggle_braket_get_data.py +0 -0
  112. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_validate_get_state.py +0 -0
  113. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_validate_handle_state.py +0 -0
  114. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/jobs/test_jobs_validate_library.py +0 -0
  115. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/kernels/__init__.py +0 -0
  116. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/kernels/test_kernels_list.py +0 -0
  117. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/resources/envs/correct.yaml +0 -0
  118. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/resources/envs/icon.png +0 -0
  119. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tests/resources/envs/incorrect.yaml +0 -0
  120. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/bump_version.py +0 -0
  121. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/create_dev_build.sh +0 -0
  122. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/install_wheel_extras.sh +0 -0
  123. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/split_md.py +0 -0
  124. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/split_rst.py +0 -0
  125. {qbraid_cli-0.10.6 → qbraid_cli-0.10.8}/tools/stamp_pre_release.py +0 -0
@@ -21,7 +21,7 @@ jobs:
21
21
  pull-requests: write
22
22
  steps:
23
23
  - name: Checkout code
24
- uses: actions/checkout@v4
24
+ uses: actions/checkout@v5
25
25
  with:
26
26
  ref: 'main'
27
27
 
@@ -29,7 +29,7 @@ jobs:
29
29
  run: git checkout -b qbraid-bot/${{ github.run_id }}
30
30
 
31
31
  - name: Setup Python
32
- uses: actions/setup-python@v5
32
+ uses: actions/setup-python@v6
33
33
  with:
34
34
  python-version: '3.11'
35
35
 
@@ -14,9 +14,9 @@ jobs:
14
14
  python-version: ['3.11']
15
15
 
16
16
  steps:
17
- - uses: actions/checkout@v4
17
+ - uses: actions/checkout@v5
18
18
  - name: Set up Python ${{ matrix.python-version }}
19
- uses: actions/setup-python@v5
19
+ uses: actions/setup-python@v6
20
20
  with:
21
21
  python-version: ${{ matrix.python-version }}
22
22
  cache: pip
@@ -44,14 +44,14 @@ jobs:
44
44
  fail-fast: true
45
45
 
46
46
  steps:
47
- - uses: actions/checkout@v4
47
+ - uses: actions/checkout@v5
48
48
  - name: Set up Python ${{ matrix.python-version }}
49
- uses: actions/setup-python@v5
49
+ uses: actions/setup-python@v6
50
50
  with:
51
51
  python-version: ${{ matrix.python-version }}
52
52
  cache: pip
53
53
  - name: Download built package
54
- uses: actions/download-artifact@v4
54
+ uses: actions/download-artifact@v5
55
55
  with:
56
56
  name: built-package
57
57
  path: dist
@@ -73,7 +73,7 @@ jobs:
73
73
  QBRAID_API_KEY: ${{ secrets.QBRAID_API_KEY }}
74
74
  - name: Upload coverage to Codecov
75
75
  if: matrix.python-version == '3.11' && matrix.os == 'ubuntu-latest'
76
- uses: codecov/codecov-action@v5.4.2
76
+ uses: codecov/codecov-action@v5.5.1
77
77
  with:
78
78
  token: ${{ secrets.CODECOV_TOKEN }}
79
79
  fail_ci_if_error: false
@@ -12,7 +12,7 @@ jobs:
12
12
  cli_version: ${{ steps.get_version.outputs.version }}
13
13
  steps:
14
14
  - name: Checkout code
15
- uses: actions/checkout@v4
15
+ uses: actions/checkout@v5
16
16
  with:
17
17
  ref: main
18
18
 
@@ -52,13 +52,13 @@ jobs:
52
52
 
53
53
  steps:
54
54
  - name: Download docs assets
55
- uses: actions/download-artifact@v4
55
+ uses: actions/download-artifact@v5
56
56
  with:
57
57
  name: api-reference
58
58
  path: ./api-reference
59
59
 
60
60
  - name: Checkout qBraid/docs repo
61
- uses: actions/checkout@v4
61
+ uses: actions/checkout@v5
62
62
  with:
63
63
  repository: qBraid/docs
64
64
  token: ${{ secrets.BOT_TOKEN }}
@@ -81,7 +81,7 @@ jobs:
81
81
  sed -i "6iVersion: [$VERSION](https://pypi.org/project/qbraid-cli/$VERSION)\n" qbraid_docs/cli/api-reference/qbraid.mdx
82
82
 
83
83
  - name: Set up Node.js
84
- uses: actions/setup-node@v4
84
+ uses: actions/setup-node@v5
85
85
  with:
86
86
  node-version: '22'
87
87
 
@@ -14,9 +14,9 @@ jobs:
14
14
  runs-on: ubuntu-latest
15
15
 
16
16
  steps:
17
- - uses: actions/checkout@v4
17
+ - uses: actions/checkout@v5
18
18
  - name: Set up Python
19
- uses: actions/setup-python@v5
19
+ uses: actions/setup-python@v6
20
20
  with:
21
21
  python-version: '3.11'
22
22
  cache: pip
@@ -12,9 +12,9 @@ jobs:
12
12
  runs-on: ubuntu-latest
13
13
 
14
14
  steps:
15
- - uses: actions/checkout@v4
15
+ - uses: actions/checkout@v5
16
16
  - name: Set up Python
17
- uses: actions/setup-python@v5
17
+ uses: actions/setup-python@v6
18
18
  with:
19
19
  python-version: '3.11'
20
20
  - name: Install dependencies
@@ -17,9 +17,9 @@ jobs:
17
17
  python-version: ['3.11']
18
18
 
19
19
  steps:
20
- - uses: actions/checkout@v4
20
+ - uses: actions/checkout@v5
21
21
  - name: Set up Python ${{ matrix.python-version }}
22
- uses: actions/setup-python@v5
22
+ uses: actions/setup-python@v6
23
23
  with:
24
24
  python-version: ${{ matrix.python-version }}
25
25
  cache: pip
@@ -47,14 +47,14 @@ jobs:
47
47
  fail-fast: true
48
48
 
49
49
  steps:
50
- - uses: actions/checkout@v4
50
+ - uses: actions/checkout@v5
51
51
  - name: Set up Python ${{ matrix.python-version }}
52
- uses: actions/setup-python@v5
52
+ uses: actions/setup-python@v6
53
53
  with:
54
54
  python-version: ${{ matrix.python-version }}
55
55
  cache: pip
56
56
  - name: Download built package
57
- uses: actions/download-artifact@v4
57
+ uses: actions/download-artifact@v5
58
58
  with:
59
59
  name: built-package
60
60
  path: dist
@@ -76,7 +76,7 @@ jobs:
76
76
  QBRAID_API_KEY: ${{ secrets.QBRAID_API_KEY }}
77
77
  - name: Upload coverage to Codecov
78
78
  if: matrix.python-version == '3.11' && matrix.os == 'ubuntu-latest'
79
- uses: codecov/codecov-action@v5.4.2
79
+ uses: codecov/codecov-action@v5.5.1
80
80
  with:
81
81
  token: ${{ secrets.CODECOV_TOKEN }}
82
82
  fail_ci_if_error: false
@@ -9,12 +9,12 @@ jobs:
9
9
  environment: publish
10
10
  runs-on: ubuntu-latest
11
11
  steps:
12
- - uses: actions/checkout@v4
12
+ - uses: actions/checkout@v5
13
13
  with:
14
14
  fetch-depth: 1
15
15
 
16
16
  - name: Set up Python
17
- uses: actions/setup-python@v5
17
+ uses: actions/setup-python@v6
18
18
  with:
19
19
  python-version: '3.11'
20
20
 
@@ -9,12 +9,12 @@ jobs:
9
9
  environment: publish
10
10
  runs-on: ubuntu-latest
11
11
  steps:
12
- - uses: actions/checkout@v4
12
+ - uses: actions/checkout@v5
13
13
  with:
14
14
  fetch-depth: 1
15
15
 
16
16
  - name: Set up Python
17
- uses: actions/setup-python@v5
17
+ uses: actions/setup-python@v6
18
18
  with:
19
19
  python-version: '3.11'
20
20
 
@@ -18,7 +18,7 @@ jobs:
18
18
  echo "version=$VERSION" >> $GITHUB_OUTPUT
19
19
 
20
20
  - name: Checkout code
21
- uses: actions/checkout@v4
21
+ uses: actions/checkout@v5
22
22
  with:
23
23
  ref: 'main'
24
24
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: qbraid-cli
3
- Version: 0.10.6
3
+ Version: 0.10.8
4
4
  Summary: Command Line Interface for interacting with all parts of the qBraid platform.
5
5
  Author-email: qBraid Development Team <contact@qbraid.com>
6
6
  License: Proprietary
@@ -29,7 +29,7 @@ Description-Content-Type: text/markdown
29
29
  License-File: LICENSE
30
30
  Requires-Dist: typer>=0.12.1
31
31
  Requires-Dist: rich>=10.11.0
32
- Requires-Dist: click
32
+ Requires-Dist: click<=8.1.8
33
33
  Requires-Dist: qbraid-core<0.2,>=0.1.41
34
34
  Provides-Extra: jobs
35
35
  Requires-Dist: amazon-braket-sdk>=1.48.1; extra == "jobs"
@@ -1,6 +1,6 @@
1
1
  sphinx>=7.2.6,<8.3.0
2
2
  sphinx-rtd-theme>=1.3,<3.1
3
- docutils<0.22
3
+ docutils<0.23
4
4
  toml
5
5
  build
6
6
  m2r
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "qbraid-cli"
7
- version = "0.10.6"
7
+ version = "0.10.8"
8
8
  description = "Command Line Interface for interacting with all parts of the qBraid platform."
9
9
  readme = "README.md"
10
10
  authors = [{ name = "qBraid Development Team", email = "contact@qbraid.com" }]
@@ -30,7 +30,7 @@ classifiers = [
30
30
  dependencies = [
31
31
  "typer>=0.12.1",
32
32
  "rich>=10.11.0",
33
- "click",
33
+ "click<=8.1.8",
34
34
  "qbraid-core>=0.1.41,<0.2",
35
35
  ]
36
36
  requires-python = ">= 3.9"
@@ -11,6 +11,7 @@ from typing import Any
11
11
  import rich
12
12
  import typer
13
13
 
14
+ from qbraid_cli.configure.actions import QBRAID_ORG_MODEL_ENABLED
14
15
  from qbraid_cli.handlers import run_progress_task
15
16
 
16
17
  account_app = typer.Typer(help="Manage qBraid account.", no_args_is_help=True)
@@ -51,9 +52,10 @@ def account_info():
51
52
  "email": user.get("email"),
52
53
  "joinedDate": user.get("createdAt", "Unknown"),
53
54
  "activePlan": user.get("activePlan", "") or "Free",
54
- "organization": personal_info.get("organization", "") or "qbraid",
55
55
  "role": personal_info.get("role", "") or "guest",
56
56
  }
57
+ if QBRAID_ORG_MODEL_ENABLED:
58
+ metadata["organization"] = personal_info.get("organization", "") or "qbraid"
57
59
 
58
60
  return metadata
59
61
 
@@ -25,6 +25,8 @@ from rich.console import Console
25
25
 
26
26
  from qbraid_cli.handlers import handle_filesystem_operation
27
27
 
28
+ QBRAID_ORG_MODEL_ENABLED = False # Set to True if organization/workspace model is enabled
29
+
28
30
 
29
31
  def validate_input(key: str, value: str) -> str:
30
32
  """Validate the user input based on the key.
@@ -96,16 +98,21 @@ def default_action(section: str = DEFAULT_CONFIG_SECTION):
96
98
 
97
99
  default_values = {
98
100
  "url": DEFAULT_ENDPOINT_URL,
99
- "organization": DEFAULT_ORGANIZATION,
100
- "workspace": DEFAULT_WORKSPACE,
101
101
  }
102
+ if QBRAID_ORG_MODEL_ENABLED:
103
+ default_values["organization"] = DEFAULT_ORGANIZATION
104
+ default_values["workspace"] = DEFAULT_WORKSPACE
102
105
 
103
106
  config[section]["url"] = prompt_for_config(config, section, "url", default_values)
104
107
  config[section]["api-key"] = prompt_for_config(config, section, "api-key", default_values)
105
- config[section]["organization"] = prompt_for_config(
106
- config, section, "organization", default_values
107
- )
108
- config[section]["workspace"] = prompt_for_config(config, section, "workspace", default_values)
108
+
109
+ if QBRAID_ORG_MODEL_ENABLED:
110
+ config[section]["organization"] = prompt_for_config(
111
+ config, section, "organization", default_values
112
+ )
113
+ config[section]["workspace"] = prompt_for_config(
114
+ config, section, "workspace", default_values
115
+ )
109
116
 
110
117
  for key in list(config[section]):
111
118
  if not config[section][key]:
@@ -12,7 +12,7 @@ import typer
12
12
  from rich.console import Console
13
13
 
14
14
  from qbraid_cli.devices.validation import validate_provider, validate_status, validate_type
15
- from qbraid_cli.handlers import run_progress_task
15
+ from qbraid_cli.handlers import print_formatted_data, run_progress_task
16
16
 
17
17
  devices_app = typer.Typer(help="Manage qBraid quantum devices.", no_args_is_help=True)
18
18
 
@@ -29,7 +29,10 @@ def devices_list( # pylint: disable=too-many-branches
29
29
  None,
30
30
  "--provider",
31
31
  "-p",
32
- help="'AWS'|'IBM'|'IonQ'|'Rigetti'|'OQC'|'QuEra'",
32
+ help=(
33
+ "'AWS'|'IBM'|'IonQ'|'Rigetti'|'OQC'|'QuEra'|'IQM'|"
34
+ "'NEC'|'qBraid'|'Azure'|'Pasqal'|'Quantinuum'|'Equal1'"
35
+ ),
33
36
  callback=validate_provider,
34
37
  ),
35
38
  ) -> None:
@@ -76,5 +79,25 @@ def devices_list( # pylint: disable=too-many-branches
76
79
  console.print(f"\n{msg}", style="italic", justify="left")
77
80
 
78
81
 
82
+ @devices_app.command(name="get")
83
+ def devices_get(
84
+ device_id: str = typer.Argument(..., help="The ID of the device to get."),
85
+ fmt: bool = typer.Option(
86
+ True, "--no-fmt", help="Disable rich console formatting (output raw data)"
87
+ ),
88
+ ) -> None:
89
+ """Get a qBraid quantum device."""
90
+
91
+ def get_device():
92
+ from qbraid_core.services.quantum import QuantumClient
93
+
94
+ client = QuantumClient()
95
+ return client.get_device(device_id)
96
+
97
+ data: dict[str, Any] = run_progress_task(get_device)
98
+
99
+ print_formatted_data(data, fmt)
100
+
101
+
79
102
  if __name__ == "__main__":
80
103
  devices_app()
@@ -128,6 +128,7 @@ def envs_create( # pylint: disable=too-many-statements
128
128
  env_config.description = environment.get("description")
129
129
  env_config.tags = environment.get("tags")
130
130
  env_config.kernel_name = environment.get("kernelName")
131
+ env_config.python_version = python_version
131
132
 
132
133
  slug_path = env_path / slug
133
134
  description = "None" if description == "" else description
@@ -27,10 +27,10 @@ def is_file_less_than_10mb(file_path: Path) -> bool:
27
27
  Returns:
28
28
  bool: True if the file is less than 10MB, False otherwise.
29
29
  """
30
- TEN_MB = 10 * 1024 * 1024 # 10 * 1024 KB * 1024 bytes
30
+ ten_mb = 10485760 # 10 MB in bytes (10 * 1024 * 1024)
31
31
 
32
32
  try:
33
- return file_path.stat().st_size < TEN_MB
33
+ return file_path.stat().st_size < ten_mb
34
34
  except OSError:
35
35
  return False
36
36
 
@@ -89,6 +89,22 @@ def handle_filesystem_operation(operation: Callable[[], None], path: Path) -> No
89
89
  raise QbraidException(f"Failed to save configuration to {path}: {err.strerror}") from err
90
90
 
91
91
 
92
+ def print_formatted_data(data: Any, fmt: bool = True) -> None:
93
+ """
94
+ Print data with optional formatting using rich console.
95
+
96
+ Args:
97
+ data (Any): The data to be printed.
98
+ fmt (bool): If True, use rich console formatting. If False, use standard print.
99
+ Defaults to True.
100
+ """
101
+ if fmt:
102
+ console = Console()
103
+ console.print(data)
104
+ else:
105
+ print(data)
106
+
107
+
92
108
  def run_progress_task(
93
109
  operation: Callable[..., Any],
94
110
  *args,
@@ -11,7 +11,7 @@ from typing import Any, Callable
11
11
  import typer
12
12
  from rich.console import Console
13
13
 
14
- from qbraid_cli.handlers import handle_error, run_progress_task
14
+ from qbraid_cli.handlers import handle_error, print_formatted_data, run_progress_task
15
15
  from qbraid_cli.jobs.toggle_braket import disable_braket, enable_braket
16
16
  from qbraid_cli.jobs.validation import handle_jobs_state, run_progress_get_state, validate_library
17
17
 
@@ -107,11 +107,8 @@ def jobs_list(
107
107
 
108
108
  result: tuple[Any, Callable] = run_progress_task(import_jobs)
109
109
  client, process_job_data = result
110
- # https://github.com/qBraid/api/issues/644
111
- # raw_data = client.search_jobs(query={"numResults": limit})
112
- raw_data = client.search_jobs(query={})
110
+ raw_data = client.search_jobs(query={"resultsPerPage": limit, "page": 0})
113
111
  job_data, msg = process_job_data(raw_data)
114
- job_data = job_data[:limit]
115
112
 
116
113
  longest_job_id = max(len(item[0]) for item in job_data)
117
114
  spacing = longest_job_id + 5
@@ -148,5 +145,25 @@ def jobs_list(
148
145
  handle_error(message="Failed to fetch quantum jobs.")
149
146
 
150
147
 
148
+ @jobs_app.command(name="get")
149
+ def jobs_get(
150
+ job_id: str = typer.Argument(..., help="The ID of the job to get."),
151
+ fmt: bool = typer.Option(
152
+ True, "--no-fmt", help="Disable rich console formatting (output raw data)"
153
+ ),
154
+ ) -> None:
155
+ """Get a qBraid Quantum Job."""
156
+
157
+ def get_job():
158
+ from qbraid_core.services.quantum import QuantumClient
159
+
160
+ client = QuantumClient()
161
+ return client.get_job(job_id)
162
+
163
+ data: dict[str, Any] = run_progress_task(get_job)
164
+
165
+ print_formatted_data(data, fmt)
166
+
167
+
151
168
  if __name__ == "__main__":
152
169
  jobs_app()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: qbraid-cli
3
- Version: 0.10.6
3
+ Version: 0.10.8
4
4
  Summary: Command Line Interface for interacting with all parts of the qBraid platform.
5
5
  Author-email: qBraid Development Team <contact@qbraid.com>
6
6
  License: Proprietary
@@ -29,7 +29,7 @@ Description-Content-Type: text/markdown
29
29
  License-File: LICENSE
30
30
  Requires-Dist: typer>=0.12.1
31
31
  Requires-Dist: rich>=10.11.0
32
- Requires-Dist: click
32
+ Requires-Dist: click<=8.1.8
33
33
  Requires-Dist: qbraid-core<0.2,>=0.1.41
34
34
  Provides-Extra: jobs
35
35
  Requires-Dist: amazon-braket-sdk>=1.48.1; extra == "jobs"
@@ -30,7 +30,6 @@ docs/_static/logo.png
30
30
  docs/_static/style/custom.css
31
31
  docs/_static/style/s4defs-roles.css
32
32
  qbraid_cli/__init__.py
33
- qbraid_cli/_version.py
34
33
  qbraid_cli/exceptions.py
35
34
  qbraid_cli/handlers.py
36
35
  qbraid_cli/main.py
@@ -83,6 +82,7 @@ tests/configure/test_configure_prompt_for_config.py
83
82
  tests/configure/test_configure_set.py
84
83
  tests/configure/test_configure_validate_input.py
85
84
  tests/devices/__init__.py
85
+ tests/devices/test_devices_get.py
86
86
  tests/devices/test_devices_list.py
87
87
  tests/devices/test_devices_validations.py
88
88
  tests/envs/__init__.py
@@ -98,6 +98,7 @@ tests/files/test_files_commands.py
98
98
  tests/jobs/__init__.py
99
99
  tests/jobs/test_jobs_disable.py
100
100
  tests/jobs/test_jobs_enable.py
101
+ tests/jobs/test_jobs_get.py
101
102
  tests/jobs/test_jobs_list.py
102
103
  tests/jobs/test_jobs_state.py
103
104
  tests/jobs/test_jobs_toggle_braket_confirm.py
@@ -1,6 +1,6 @@
1
1
  typer>=0.12.1
2
2
  rich>=10.11.0
3
- click
3
+ click<=8.1.8
4
4
  qbraid-core<0.2,>=0.1.41
5
5
 
6
6
  [dev]
@@ -51,7 +51,6 @@ def test_account_info_success():
51
51
  "email": "mock@example.com",
52
52
  "joinedDate": "2022-03-10T03:52:08.743Z",
53
53
  "activePlan": "Free",
54
- "organization": "qbraid",
55
54
  "role": "guest",
56
55
  }
57
56
 
@@ -66,7 +65,6 @@ def test_account_info_success():
66
65
  "email": "mock@example.com",
67
66
  "createdAt": "2022-03-10T03:52:08.743Z",
68
67
  "activePlan": "Free",
69
- "organization": "qbraid",
70
68
  "role": "guest",
71
69
  }
72
70
 
@@ -41,7 +41,6 @@ def test_configure_list_with_values(capsys):
41
41
  "api-key": "abcdef123456",
42
42
  "refresh-token": "xyz987654321",
43
43
  "url": "https://example.com",
44
- "organization": "test-org",
45
44
  }
46
45
  }
47
46
  mock_load_config = MagicMock(return_value=mock_config)
@@ -55,7 +54,32 @@ def test_configure_list_with_values(capsys):
55
54
  assert "*****321" in captured.out # last 3 chars of refresh-token
56
55
  # Check that non-sensitive values are shown in full
57
56
  assert "https://example.com" in captured.out
58
- assert "test-org" in captured.out
57
+
58
+
59
+ def test_configure_list_with_org_enabled_config(capsys):
60
+ """Test configure_list with organization and workspace when org model is enabled."""
61
+ mock_config = {
62
+ "default": {
63
+ "api-key": "abcdef123456",
64
+ "refresh-token": "xyz987654321",
65
+ "url": "https://example.com",
66
+ "organization": "my-org",
67
+ "workspace": "my-workspace",
68
+ }
69
+ }
70
+ mock_load_config = MagicMock(return_value=mock_config)
71
+ with patch("qbraid_cli.configure.actions.QBRAID_ORG_MODEL_ENABLED", True):
72
+ with patch("qbraid_core.config.load_config", mock_load_config):
73
+ configure_list()
74
+ captured = capsys.readouterr()
75
+
76
+ # Check that sensitive values are masked
77
+ assert "*****456" in captured.out # last 3 chars of api-key
78
+ assert "*****321" in captured.out # last 3 chars of refresh-token
79
+ # Check that non-sensitive values are shown in full
80
+ assert "https://example.com" in captured.out
81
+ assert "my-org" in captured.out
82
+ assert "my-workspace" in captured.out
59
83
 
60
84
 
61
85
  def test_configure_get_success(capsys):
@@ -0,0 +1,61 @@
1
+ # Copyright (c) 2024, qBraid Development Team
2
+ # All rights reserved.
3
+
4
+ """
5
+ Unit tests for the default_action function in the configure app.
6
+
7
+ """
8
+
9
+ import configparser
10
+ from unittest.mock import patch
11
+
12
+ import pytest
13
+
14
+ from qbraid_cli.configure.actions import default_action
15
+
16
+
17
+ @pytest.mark.parametrize(
18
+ "org_model_enabled,side_effect,expected_call_count",
19
+ [
20
+ (False, ["https://new.example.com", "api-key-123"], 2),
21
+ (True, ["https://api.qbraid.com", "api-key-456", "qbraid-org", "default-workspace"], 4),
22
+ ],
23
+ )
24
+ def test_default_action(org_model_enabled, side_effect, expected_call_count):
25
+ """Test default_action method with mocked dependencies."""
26
+ # Store original value of QBRAID_ORG_MODEL_ENABLED
27
+ import qbraid_cli.configure.actions as actions_module
28
+
29
+ original_org_model_enabled = actions_module.QBRAID_ORG_MODEL_ENABLED
30
+
31
+ try:
32
+ # Set the org model enabled flag for this test
33
+ actions_module.QBRAID_ORG_MODEL_ENABLED = org_model_enabled
34
+
35
+ with (
36
+ patch("qbraid_cli.configure.actions.load_config") as mock_load_config,
37
+ patch("qbraid_cli.configure.actions.prompt_for_config") as mock_prompt,
38
+ patch("qbraid_cli.configure.actions.handle_filesystem_operation") as mock_handle_fs,
39
+ patch("qbraid_cli.configure.actions.Console") as mock_console,
40
+ ):
41
+ # Setup mock returns
42
+ config = configparser.ConfigParser()
43
+ config.add_section("default")
44
+ mock_load_config.return_value = config
45
+ mock_prompt.side_effect = side_effect
46
+ mock_console_instance = mock_console.return_value
47
+
48
+ # Call the function to test
49
+ default_action()
50
+
51
+ # Verify prompt_for_config was called the expected number of times
52
+ assert mock_prompt.call_count == expected_call_count
53
+ mock_load_config.assert_called_once()
54
+ mock_handle_fs.assert_called_once()
55
+ mock_console_instance.print.assert_called_once_with(
56
+ "\n[bold green]Configuration updated successfully."
57
+ )
58
+
59
+ finally:
60
+ # Restore original value
61
+ actions_module.QBRAID_ORG_MODEL_ENABLED = original_org_model_enabled
@@ -9,7 +9,7 @@ Unit tests for the prompt_for_config function in the configure app.
9
9
  import configparser
10
10
  from unittest.mock import patch
11
11
 
12
- from qbraid_cli.configure.actions import default_action, prompt_for_config
12
+ from qbraid_cli.configure.actions import prompt_for_config
13
13
 
14
14
 
15
15
  def test_enter_new_values():
@@ -20,8 +20,6 @@ def test_enter_new_values():
20
20
  # Initial values
21
21
  settings = [
22
22
  ("url", "http://example.com", "http://newexample.com"),
23
- ("organization", "default-org", "new-org"),
24
- ("workspace", "default-workspace", "new-workspace"),
25
23
  ]
26
24
 
27
25
  # Setup config with initial values