Python-gitlab

Latest version: v5.6.0

Safety actively analyzes 723576 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 8 of 13

3.3.0

Not secure
Bug Fixes

- Support RateLimit-Reset header
([`4060146`](https://github.com/python-gitlab/python-gitlab/commit/40601463c78a6f5d45081700164899b2559b7e55))

Some endpoints are not returning the `Retry-After` header when rate-limiting occurrs. In those cases
use the `RateLimit-Reset` [1] header, if available.

Closes: 1889

[1]
https://docs.gitlab.com/ee/user/admin_area/settings/user_and_ip_rate_limits.html#response-headers

Chores

- **deps**: Update actions/checkout action to v3
([`7333cbb`](https://github.com/python-gitlab/python-gitlab/commit/7333cbb65385145a14144119772a1854b41ea9d8))

- **deps**: Update actions/setup-python action to v3
([`7f845f7`](https://github.com/python-gitlab/python-gitlab/commit/7f845f7eade3c0cdceec6bfe7b3d087a8586edc5))

- **deps**: Update actions/stale action to v5
([`d841185`](https://github.com/python-gitlab/python-gitlab/commit/d8411853e224a198d0ead94242acac3aadef5adc))

- **deps**: Update actions/upload-artifact action to v3
([`18a0eae`](https://github.com/python-gitlab/python-gitlab/commit/18a0eae11c480d6bd5cf612a94e56cb9562e552a))

- **deps**: Update black to v22
([`3f84f1b`](https://github.com/python-gitlab/python-gitlab/commit/3f84f1bb805691b645fac2d1a41901abefccb17e))

- **deps**: Update dependency mypy to v0.931
([`33646c1`](https://github.com/python-gitlab/python-gitlab/commit/33646c1c4540434bed759d903c9b83af4e7d1a82))

- **deps**: Update dependency mypy to v0.940
([`dd11084`](https://github.com/python-gitlab/python-gitlab/commit/dd11084dd281e270a480b338aba88b27b991e58e))

- **deps**: Update dependency mypy to v0.941
([`3a9d4f1`](https://github.com/python-gitlab/python-gitlab/commit/3a9d4f1dc2069e29d559967e1f5498ccadf62591))

- **deps**: Update dependency mypy to v0.942
([`8ba0f8c`](https://github.com/python-gitlab/python-gitlab/commit/8ba0f8c6b42fa90bd1d7dd7015a546e8488c3f73))

- **deps**: Update dependency pylint to v2.13.0
([`5fa403b`](https://github.com/python-gitlab/python-gitlab/commit/5fa403bc461ed8a4d183dcd8f696c2a00b64a33d))

- **deps**: Update dependency pylint to v2.13.1
([`eefd724`](https://github.com/python-gitlab/python-gitlab/commit/eefd724545de7c96df2f913086a7f18020a5470f))

- **deps**: Update dependency pylint to v2.13.2
([`10f15a6`](https://github.com/python-gitlab/python-gitlab/commit/10f15a625187f2833be72d9bf527e75be001d171))

- **deps**: Update dependency pytest to v7
([`ae8d70d`](https://github.com/python-gitlab/python-gitlab/commit/ae8d70de2ad3ceb450a33b33e189bb0a3f0ff563))

- **deps**: Update dependency pytest to v7.1.0
([`27c7e33`](https://github.com/python-gitlab/python-gitlab/commit/27c7e3350839aaf5c06a15c1482fc2077f1d477a))

- **deps**: Update dependency pytest to v7.1.1
([`e31f2ef`](https://github.com/python-gitlab/python-gitlab/commit/e31f2efe97995f48c848f32e14068430a5034261))

- **deps**: Update dependency pytest-console-scripts to v1.3
([`9c202dd`](https://github.com/python-gitlab/python-gitlab/commit/9c202dd5a2895289c1f39068f0ea09812f28251f))

- **deps**: Update dependency pytest-console-scripts to v1.3.1
([`da392e3`](https://github.com/python-gitlab/python-gitlab/commit/da392e33e58d157169e5aa3f1fe725457e32151c))

- **deps**: Update dependency requests to v2.27.1
([`95dad55`](https://github.com/python-gitlab/python-gitlab/commit/95dad55b0cb02fd30172b5b5b9b05a25473d1f03))

- **deps**: Update dependency sphinx to v4.4.0
([`425d161`](https://github.com/python-gitlab/python-gitlab/commit/425d1610ca19be775d9fdd857e61d8b4a4ae4db3))

- **deps**: Update dependency sphinx to v4.5.0
([`36ab769`](https://github.com/python-gitlab/python-gitlab/commit/36ab7695f584783a4b3272edd928de3b16843a36))

- **deps**: Update dependency types-requests to v2.27.12
([`8cd668e`](https://github.com/python-gitlab/python-gitlab/commit/8cd668efed7bbbca370634e8c8cb10e3c7a13141))

- **deps**: Update dependency types-requests to v2.27.14
([`be6b54c`](https://github.com/python-gitlab/python-gitlab/commit/be6b54c6028036078ef09013f6c51c258173f3ca))

- **deps**: Update dependency types-requests to v2.27.15
([`2e8ecf5`](https://github.com/python-gitlab/python-gitlab/commit/2e8ecf569670afc943e8a204f3b2aefe8aa10d8b))

- **deps**: Update dependency types-setuptools to v57.4.10
([`b37fc41`](https://github.com/python-gitlab/python-gitlab/commit/b37fc4153a00265725ca655bc4482714d6b02809))

- **deps**: Update pre-commit hook alessandrojcm/commitlint-pre-commit-hook to v8
([`5440780`](https://github.com/python-gitlab/python-gitlab/commit/544078068bc9d7a837e75435e468e4749f7375ac))

- **deps**: Update pre-commit hook pycqa/pylint to v2.13.0
([`9fe60f7`](https://github.com/python-gitlab/python-gitlab/commit/9fe60f7b8fa661a8bba61c04fcb5b54359ac6778))

- **deps**: Update pre-commit hook pycqa/pylint to v2.13.1
([`1d0c6d4`](https://github.com/python-gitlab/python-gitlab/commit/1d0c6d423ce9f6c98511578acbb0f08dc4b93562))

- **deps**: Update pre-commit hook pycqa/pylint to v2.13.2
([`14d367d`](https://github.com/python-gitlab/python-gitlab/commit/14d367d60ab8f1e724c69cad0f39c71338346948))

- **deps**: Update typing dependencies
([`21e7c37`](https://github.com/python-gitlab/python-gitlab/commit/21e7c3767aa90de86046a430c7402f0934950e62))

- **deps**: Update typing dependencies
([`37a7c40`](https://github.com/python-gitlab/python-gitlab/commit/37a7c405c975359e9c1f77417e67063326c82a42))

Code Style

- Reformat for black v22
([`93d4403`](https://github.com/python-gitlab/python-gitlab/commit/93d4403f0e46ed354cbcb133821d00642429532f))

Documentation

- Add pipeline test report summary support
([`d78afb3`](https://github.com/python-gitlab/python-gitlab/commit/d78afb36e26f41d727dee7b0952d53166e0df850))

- Fix typo and incorrect style
([`2828b10`](https://github.com/python-gitlab/python-gitlab/commit/2828b10505611194bebda59a0e9eb41faf24b77b))

- **chore**: Include docs .js files in sdist
([`3010b40`](https://github.com/python-gitlab/python-gitlab/commit/3010b407bc9baabc6cef071507e8fa47c0f1624d))

Features

- **object**: Add pipeline test report summary support
([`a97e0cf`](https://github.com/python-gitlab/python-gitlab/commit/a97e0cf81b5394b3a2b73d927b4efe675bc85208))

3.2.0

Not secure
Bug Fixes

- Remove custom `delete` method for labels
([`0841a2a`](https://github.com/python-gitlab/python-gitlab/commit/0841a2a686c6808e2f3f90960e529b26c26b268f))

The usage of deleting was incorrect according to the current API. Remove custom `delete()` method as
not needed.

Add tests to show it works with labels needing to be encoded.

Also enable the test_group_labels() test function. Previously it was disabled.

Add ability to do a `get()` for group labels.

Closes: 1867

- **services**: Use slug for id_attr instead of custom methods
([`e30f39d`](https://github.com/python-gitlab/python-gitlab/commit/e30f39dff5726266222b0f56c94f4ccfe38ba527))

Chores

- Correct type-hints for per_page attrbute
([`e825653`](https://github.com/python-gitlab/python-gitlab/commit/e82565315330883823bd5191069253a941cb2683))

There are occasions where a GitLab `list()` call does not return the `x-per-page` header. For
example the listing of custom attributes.

Update the type-hints to reflect that.

- Create a custom `warnings.warn` wrapper
([`6ca9aa2`](https://github.com/python-gitlab/python-gitlab/commit/6ca9aa2960623489aaf60324b4709848598aec91))

Create a custom `warnings.warn` wrapper that will walk the stack trace to find the first frame
outside of the `gitlab/` path to print the warning against. This will make it easier for users to
find where in their code the error is generated from

- Create new ArrayAttribute class
([`a57334f`](https://github.com/python-gitlab/python-gitlab/commit/a57334f1930752c70ea15847a39324fa94042460))

Create a new ArrayAttribute class. This is to indicate types which are sent to the GitLab server as
arrays https://docs.gitlab.com/ee/api/#array

At this stage it is identical to the CommaSeparatedListAttribute class but will be used later to
support the array types sent to GitLab.

This is the second step in a series of steps of our goal to add full support for the GitLab API data
types[1]: * array * hash * array of hashes

Step one was: commit 5127b1594c00c7364e9af15e42d2e2f2d909449b

[1] https://docs.gitlab.com/ee/api/#encoding-api-parameters-of-array-and-hash-types

Related: 1698

- Require kwargs for `utils.copy_dict()`
([`7cf35b2`](https://github.com/python-gitlab/python-gitlab/commit/7cf35b2c0e44732ca02b74b45525cc7c789457fb))

The non-keyword arguments were a tiny bit confusing as the destination was first and the source was
second.

Change the order and require key-word only arguments to ensure we don't silently break anyone.

- **ci**: Do not run release workflow in forks
([`2b6edb9`](https://github.com/python-gitlab/python-gitlab/commit/2b6edb9a0c62976ff88a95a953e9d3f2c7f6f144))

Code Style

- **objects**: Add spacing to docstrings
([`700d25d`](https://github.com/python-gitlab/python-gitlab/commit/700d25d9bd812a64f5f1287bf50e8ddc237ec553))

Documentation

- Add delete methods for runners and project artifacts
([`5e711fd`](https://github.com/python-gitlab/python-gitlab/commit/5e711fdb747fb3dcde1f5879c64dfd37bf25f3c0))

- Add retry_transient infos
([`bb1f054`](https://github.com/python-gitlab/python-gitlab/commit/bb1f05402887c78f9898fbd5bd66e149eff134d9))

Co-authored-by: Nejc Habjan <hab.nejcgmail.com>

- Add transient errors retry info
([`b7a1266`](https://github.com/python-gitlab/python-gitlab/commit/b7a126661175a3b9b73dbb4cb88709868d6d871c))

- Enable gitter chat directly in docs
([`bd1ecdd`](https://github.com/python-gitlab/python-gitlab/commit/bd1ecdd5ad654b01b34e7a7a96821cc280b3ca67))

- Revert "chore: add temporary banner for v3"
([1864](https://github.com/python-gitlab/python-gitlab/pull/1864),
[`7a13b9b`](https://github.com/python-gitlab/python-gitlab/commit/7a13b9bfa4aead6c731f9a92e0946dba7577c61b))

This reverts commit a349793307e3a975bb51f864b48e5e9825f70182.

Co-authored-by: Wadim Klincov <wadim.klincovsiemens.com>

- **artifacts**: Deprecate artifacts() and artifact() methods
([`64d01ef`](https://github.com/python-gitlab/python-gitlab/commit/64d01ef23b1269b705350106d8ddc2962a780dce))

Features

- **artifacts**: Add support for project artifacts delete API
([`c01c034`](https://github.com/python-gitlab/python-gitlab/commit/c01c034169789e1d20fd27a0f39f4c3c3628a2bb))

- **merge_request_approvals**: Add support for deleting MR approval rules
([`85a734f`](https://github.com/python-gitlab/python-gitlab/commit/85a734fec3111a4a5c4f0ddd7cb36eead96215e9))

- **mixins**: Allow deleting resources without IDs
([`0717517`](https://github.com/python-gitlab/python-gitlab/commit/0717517212b616cfd52cfd38dd5c587ff8f9c47c))

- **objects**: Add a complete artifacts manager
([`c8c2fa7`](https://github.com/python-gitlab/python-gitlab/commit/c8c2fa763558c4d9906e68031a6602e007fec930))

Testing

- **functional**: Fix GitLab configuration to support pagination
([`5b7d00d`](https://github.com/python-gitlab/python-gitlab/commit/5b7d00df466c0fe894bafeb720bf94ffc8cd38fd))

When pagination occurs python-gitlab uses the URL provided by the GitLab server to use for the next
request.

We had previously set the GitLab server configuraiton to say its URL was `http://gitlab.test` which
is not in DNS. Set the hostname in the URL to `http://127.0.0.1:8080` which is the correct URL for
the GitLab server to be accessed while doing functional tests.

Closes: 1877

- **objects**: Add tests for project artifacts
([`8ce0336`](https://github.com/python-gitlab/python-gitlab/commit/8ce0336325b339fa82fe4674a528f4bb59963df7))

- **runners**: Add test for deleting runners by auth token
([`14b88a1`](https://github.com/python-gitlab/python-gitlab/commit/14b88a13914de6ee54dd2a3bd0d5960a50578064))

- **services**: Add functional tests for services
([`2fea2e6`](https://github.com/python-gitlab/python-gitlab/commit/2fea2e64c554fd92d14db77cc5b1e2976b27b609))

- **unit**: Clean up MR approvals fixtures
([`0eb4f7f`](https://github.com/python-gitlab/python-gitlab/commit/0eb4f7f06c7cfe79c5d6695be82ac9ca41c8057e))

3.1.1

Not secure
Bug Fixes

- **cli**: Allow custom methods in managers
([`8dfed0c`](https://github.com/python-gitlab/python-gitlab/commit/8dfed0c362af2c5e936011fd0b488b8b05e8a8a0))

- **cli**: Make 'per_page' and 'page' type explicit
([`d493a5e`](https://github.com/python-gitlab/python-gitlab/commit/d493a5e8685018daa69c92e5942cbe763e5dac62))

- **cli**: Make 'timeout' type explicit
([`bbb7df5`](https://github.com/python-gitlab/python-gitlab/commit/bbb7df526f4375c438be97d8cfa0d9ea9d604e7d))

- **objects**: Make resource access tokens and repos available in CLI
([`e0a3a41`](https://github.com/python-gitlab/python-gitlab/commit/e0a3a41ce60503a25fa5c26cf125364db481b207))

Chores

- Always use context manager for file IO
([`e8031f4`](https://github.com/python-gitlab/python-gitlab/commit/e8031f42b6804415c4afee4302ab55462d5848ac))

- Consistently use open() encoding and file descriptor
([`dc32d54`](https://github.com/python-gitlab/python-gitlab/commit/dc32d54c49ccc58c01cd436346a3fbfd4a538778))

- Create return type-hints for `get_id()` & `encoded_id`
([`0c3a1d1`](https://github.com/python-gitlab/python-gitlab/commit/0c3a1d163895f660340a6c2b2f196ad996542518))

Create return type-hints for `RESTObject.get_id()` and `RESTObject.encoded_id`. Previously was
saying they return Any. Be more precise in saying they can return either: None, str, or int.

- Don't explicitly pass args to super()
([`618267c`](https://github.com/python-gitlab/python-gitlab/commit/618267ced7aaff46d8e03057fa0cab48727e5dc0))

- Remove old-style classes
([`ae2a015`](https://github.com/python-gitlab/python-gitlab/commit/ae2a015db1017d3bf9b5f1c5893727da9b0c937f))

- Remove redundant list comprehension
([`271cfd3`](https://github.com/python-gitlab/python-gitlab/commit/271cfd3651e4e9cda974d5c3f411cecb6dca6c3c))

- Rename `gitlab/__version__.py` -> `gitlab/_version.py`
([`b981ce7`](https://github.com/python-gitlab/python-gitlab/commit/b981ce7fed88c5d86a3fffc4ee3f99be0b958c1d))

It is confusing to have a `gitlab/__version__.py` because we also create a variable
`gitlab.__version__` which can conflict with `gitlab/__version__.py`.

For example in `gitlab/const.py` we have to know that `gitlab.__version__` is a module and not the
variable due to the ordering of imports. But in most other usage `gitlab.__version__` is a version
string.

To reduce confusion make the name of the version file `gitlab/_version.py`.

- Rename `types.ListAttribute` to `types.CommaSeparatedListAttribute`
([`5127b15`](https://github.com/python-gitlab/python-gitlab/commit/5127b1594c00c7364e9af15e42d2e2f2d909449b))

This name more accurately describes what the type is. Also this is the first step in a series of
steps of our goal to add full support for the GitLab API data types[1]: * array * hash * array of
hashes

[1] https://docs.gitlab.com/ee/api/#encoding-api-parameters-of-array-and-hash-types

- Use dataclass for RequiredOptional
([`30117a3`](https://github.com/python-gitlab/python-gitlab/commit/30117a3b6a8ee24362de798b2fa596a343b8774f))

- **tests**: Use method `projects.transfer()`
([`e5af2a7`](https://github.com/python-gitlab/python-gitlab/commit/e5af2a720cb5f97e5a7a5f639095fad76a48f218))

When doing the functional tests use the new function `projects.transfer` instead of the deprecated
function `projects.transfer_project()`

Code Style

- Use f-strings where applicable
([`cfed622`](https://github.com/python-gitlab/python-gitlab/commit/cfed62242e93490b8548c79f4ad16bd87de18e3e))

- Use literals to declare data structures
([`019a40f`](https://github.com/python-gitlab/python-gitlab/commit/019a40f840da30c74c1e74522a7707915061c756))

Documentation

- Enhance release docs for CI_JOB_TOKEN usage
([`5d973de`](https://github.com/python-gitlab/python-gitlab/commit/5d973de8a5edd08f38031cf9be2636b0e12f008d))

- **changelog**: Add missing changelog items
([`01755fb`](https://github.com/python-gitlab/python-gitlab/commit/01755fb56a5330aa6fa4525086e49990e57ce50b))

Testing

- Add a meta test to make sure that v4/objects/ files are imported
([`9c8c804`](https://github.com/python-gitlab/python-gitlab/commit/9c8c8043e6d1d9fadb9f10d47d7f4799ab904e9c))

Add a test to make sure that all of the `gitlab/v4/objects/` files are imported in
`gitlab/v4/objects/__init__.py`

- Convert usage of `match_querystring` to `match`
([`d16e41b`](https://github.com/python-gitlab/python-gitlab/commit/d16e41bda2c355077cbdc419fe2e1d994fdea403))

In the `responses` library the usage of `match_querystring` is deprecated. Convert to using `match`

- Remove usage of httpmock library
([`5254f19`](https://github.com/python-gitlab/python-gitlab/commit/5254f193dc29d8854952aada19a72e5b4fc7ced0))

Convert all usage of the `httpmock` library to using the `responses` library.

- Use 'responses' in test_mixins_methods.py
([`208da04`](https://github.com/python-gitlab/python-gitlab/commit/208da04a01a4b5de8dc34e62c87db4cfa4c0d9b6))

Convert from httmock to responses in test_mixins_methods.py

This leaves only one file left to convert

3.1.0

Not secure
Bug Fixes

- Broken URL for FAQ about attribute-error-list
([`1863f30`](https://github.com/python-gitlab/python-gitlab/commit/1863f30ea1f6fb7644b3128debdbb6b7bb218836))

The URL was missing a 'v' before the version number and thus the page did not exist.

Previously the URL for python-gitlab 3.0.0 was:
https://python-gitlab.readthedocs.io/en/3.0.0/faq.html#attribute-error-list

Which does not exist.

Change it to: https://python-gitlab.readthedocs.io/en/v3.0.0/faq.html#attribute-error-list add the
'v' --------------------------^

- Change to `http_list` for some ProjectCommit methods
([`497e860`](https://github.com/python-gitlab/python-gitlab/commit/497e860d834d0757d1c6532e107416c6863f52f2))

Fix the type-hints and use `http_list()` for the ProjectCommits methods: - diff() - merge_requests()
- refs()

This will enable using the pagination support we have for lists.

Closes: 1805

Closes: 1231

- Remove custom URL encoding
([`3d49e5e`](https://github.com/python-gitlab/python-gitlab/commit/3d49e5e6a2bf1c9a883497acb73d7ce7115b804d))

We were using `str.replace()` calls to take care of URL encoding issues.

Switch them to use our `utils._url_encode()` function which itself uses `urllib.parse.quote()`

Closes: 1356

- Remove default arguments for mergerequests.merge()
([`8e589c4`](https://github.com/python-gitlab/python-gitlab/commit/8e589c43fa2298dc24b97423ffcc0ce18d911e3b))

The arguments `should_remove_source_branch` and `merge_when_pipeline_succeeds` are optional
arguments. We should not be setting any default value for them.

https://docs.gitlab.com/ee/api/merge_requests.html#accept-mr

Closes: 1750

- Use url-encoded ID in all paths
([`12435d7`](https://github.com/python-gitlab/python-gitlab/commit/12435d74364ca881373d690eab89d2e2baa62a49))

Make sure all usage of the ID in the URL path is encoded. Normally it isn't an issue as most IDs are
integers or strings which don't contain a slash ('/'). But when the ID is a string with a slash
character it will break things.

Add a test case that shows this fixes wikis issue with subpages which use the slash character.

Closes: 1079

- **api**: Services: add missing `lazy` parameter
([`888f332`](https://github.com/python-gitlab/python-gitlab/commit/888f3328d3b1c82a291efbdd9eb01f11dff0c764))

Commit 8da0b758c589f608a6ae4eeb74b3f306609ba36d added the `lazy` parameter to the services `get()`
method but missed then using the `lazy` parameter when it called `super(...).get(...)`

Closes: 1828

- **cli**: Add missing list filters for environments
([`6f64d40`](https://github.com/python-gitlab/python-gitlab/commit/6f64d4098ed4a890838c6cf43d7a679e6be4ac6c))

- **cli**: Url-encode path components of the URL
([`ac1c619`](https://github.com/python-gitlab/python-gitlab/commit/ac1c619cae6481833f5df91862624bf0380fef67))

In the CLI we need to make sure the components put into the path portion of the URL are url-encoded.
Otherwise they will be interpreted as part of the path. For example can specify the project ID as
a path, but in the URL it must be url-encoded or it doesn't work.

Also stop adding the components of the path as query parameters in the URL.

Closes: 783

Closes: 1498

- **members**: Use new *All objects for *AllManager managers
([`755e0a3`](https://github.com/python-gitlab/python-gitlab/commit/755e0a32e8ca96a3a3980eb7d7346a1a899ad58b))

Change it so that:

GroupMemberAllManager uses GroupMemberAll object ProjectMemberAllManager uses ProjectMemberAll
object

Create GroupMemberAll and ProjectMemberAll objects that do not support any Mixin type methods.
Previously we were using GroupMember and ProjectMember which support the `save()` and `delete()`
methods but those methods will not work with objects retrieved using the `/members/all/` API
calls.

`list()` API calls: [1] GET /groups/:id/members/all GET /projects/:id/members/all

`get()` API calls: [2] GET /groups/:id/members/all/:user_id GET /projects/:id/members/all/:user_id

Closes: 1825

Closes: 848

[1]
https://docs.gitlab.com/ee/api/members.html#list-all-members-of-a-group-or-project-including-inherited-and-invited-members
[2]
https://docs.gitlab.com/ee/api/members.html#get-a-member-of-a-group-or-project-including-inherited-and-invited-members

Chores

- Add `pprint()` and `pformat()` methods to RESTObject
([`d69ba04`](https://github.com/python-gitlab/python-gitlab/commit/d69ba0479a4537bbc7a53f342661c1984382f939))

This is useful in debugging and testing. As can easily print out the values from an instance in a
more human-readable form.

- Add a stale workflow
([`2c036a9`](https://github.com/python-gitlab/python-gitlab/commit/2c036a992c9d7fdf6ccf0d3132d9b215c6d197f5))

Use the stale action to close issues and pull-requests with no activity.

Issues: It will mark them as stale after 60 days and then close

them once they have been stale for 15 days.

Pull-Requests: It will mark pull-requests as stale after 90 days and then close

https://github.com/actions/stale

Closes: 1649

- Add EncodedId string class to use to hold URL-encoded paths
([`a2e7c38`](https://github.com/python-gitlab/python-gitlab/commit/a2e7c383e10509b6eb0fa8760727036feb0807c8))

Add EncodedId string class. This class returns a URL-encoded string but ensures it will only
URL-encode it once even if recursively called.

Also added some functional tests of 'lazy' objects to make sure they work.

- Add functional test of mergerequest.get()
([`a92b55b`](https://github.com/python-gitlab/python-gitlab/commit/a92b55b81eb3586e4144f9332796c94747bf9cfe))

Add a functional test of test mergerequest.get() and mergerequest.get(..., lazy=True)

Closes: 1425

- Add logging to `tests/functional/conftest.py`
([`a1ac9ae`](https://github.com/python-gitlab/python-gitlab/commit/a1ac9ae63828ca2012289817410d420da066d8df))

I have found trying to debug issues in the functional tests can be difficult. Especially when trying
to figure out failures in the CI running on Github.

Add logging to `tests/functional/conftest.py` to have a better understanding of what is happening
during a test run which is useful when trying to troubleshoot issues in the CI.

- Add temporary banner for v3
([`a349793`](https://github.com/python-gitlab/python-gitlab/commit/a349793307e3a975bb51f864b48e5e9825f70182))

- Fix functional test failure if config present
([`c9ed3dd`](https://github.com/python-gitlab/python-gitlab/commit/c9ed3ddc1253c828dc877dcd55000d818c297ee7))

Previously c8256a5933d745f70c7eea0a7d6230b51bac0fbc was done to fix this but it missed two other
failures.

- Fix missing comma
([`7c59fac`](https://github.com/python-gitlab/python-gitlab/commit/7c59fac12fe69a1080cc227512e620ac5ae40b13))

There was a missing comma which meant the strings were concatenated instead of being two separate
strings.

- Ignore intermediate coverage artifacts
([`110ae91`](https://github.com/python-gitlab/python-gitlab/commit/110ae9100b407356925ac2d2ffc65e0f0d50bd70))

- Replace usage of utils._url_encode() with utils.EncodedId()
([`b07eece`](https://github.com/python-gitlab/python-gitlab/commit/b07eece0a35dbc48076c9ec79f65f1e3fa17a872))

utils.EncodedId() has basically the same functionalityy of using utils._url_encode(). So remove
utils._url_encode() as we don't need it.

- **dist**: Add docs *.md files to sdist
([`d9457d8`](https://github.com/python-gitlab/python-gitlab/commit/d9457d860ae7293ca218ab25e9501b0f796caa57))

build_sphinx to fail due to setup.cfg warning-is-error

- **docs**: Use admonitions consistently
([`55c67d1`](https://github.com/python-gitlab/python-gitlab/commit/55c67d1fdb81dcfdf8f398b3184fc59256af513d))

- **groups**: Use encoded_id for group path
([`868f243`](https://github.com/python-gitlab/python-gitlab/commit/868f2432cae80578d99db91b941332302dd31c89))

- **objects**: Use `self.encoded_id` where applicable
([`75758bf`](https://github.com/python-gitlab/python-gitlab/commit/75758bf26bca286ec57d5cef2808560c395ff7ec))

Updated a few remaining usages of `self.id` to use `self.encoded_id` as for the most part we
shouldn't be using `self.id`

There are now only a few (4 lines of code) remaining uses of `self.id`, most of which seem that they
should stay that way.

- **objects**: Use `self.encoded_id` where could be a string
([`c3c3a91`](https://github.com/python-gitlab/python-gitlab/commit/c3c3a914fa2787ae6a1368fe6550585ee252c901))

Updated a few remaining usages of `self.id` to use `self.encoded_id` where it could be a string
value.

- **projects**: Fix typing for transfer method
([`0788fe6`](https://github.com/python-gitlab/python-gitlab/commit/0788fe677128d8c25db1cc107fef860a5a3c2a42))

Co-authored-by: John Villalovos <johnsodarock.com>

Continuous Integration

- Don't fail CI if unable to upload the code coverage data
([`d5b3744`](https://github.com/python-gitlab/python-gitlab/commit/d5b3744c26c8c78f49e69da251cd53da70b180b3))

If a CI job can't upload coverage results to codecov.com it causes the CI to fail and code can't be
merged.

Documentation

- Update project access token API reference link
([`73ae955`](https://github.com/python-gitlab/python-gitlab/commit/73ae9559dc7f4fba5c80862f0f253959e60f7a0c))

- **cli**: Make examples more easily navigable by generating TOC
([`f33c523`](https://github.com/python-gitlab/python-gitlab/commit/f33c5230cb25c9a41e9f63c0846c1ecba7097ee7))

Features

- Add support for Group Access Token API
([`c01b7c4`](https://github.com/python-gitlab/python-gitlab/commit/c01b7c494192c5462ec673848287ef2a5c9bd737))

See https://docs.gitlab.com/ee/api/group_access_tokens.html

- Add support for Groups API method `transfer()`
([`0007006`](https://github.com/python-gitlab/python-gitlab/commit/0007006c184c64128caa96b82dafa3db0ea1101f))

- **api**: Add `project.transfer()` and deprecate `transfer_project()`
([`259668a`](https://github.com/python-gitlab/python-gitlab/commit/259668ad8cb54348e4a41143a45f899a222d2d35))

- **api**: Return result from `SaveMixin.save()`
([`e6258a4`](https://github.com/python-gitlab/python-gitlab/commit/e6258a4193a0e8d0c3cf48de15b926bebfa289f3))

Return the new object data when calling `SaveMixin.save()`.

Also remove check for `None` value when calling `self.manager.update()` as that method only returns
a dictionary.

Closes: 1081

Testing

- **groups**: Enable group transfer tests
([`57bb67a`](https://github.com/python-gitlab/python-gitlab/commit/57bb67ae280cff8ac6e946cd3f3797574a574f4a))

3.0.0

Not secure
Bug Fixes

- Handle situation where GitLab does not return values
([`cb824a4`](https://github.com/python-gitlab/python-gitlab/commit/cb824a49af9b0d155b89fe66a4cfebefe52beb7a))

If a query returns more than 10,000 records than the following values are NOT returned:
x.total_pages x.total

Modify the code to allow no value to be set for these values. If there is not a value returned the
functions will now return None.

Update unit test so no longer `xfail`

https://docs.gitlab.com/ee/user/gitlab_com/index.html#pagination-response-headers

Closes 1686

- Raise error if there is a 301/302 redirection
([`d56a434`](https://github.com/python-gitlab/python-gitlab/commit/d56a4345c1ae05823b553e386bfa393541117467))

Before we raised an error if there was a 301, 302 redirect but only from an http URL to an https
URL. But we didn't raise an error for any other redirects.

This caused two problems:

1. PUT requests that are redirected get changed to GET requests which don't perform the desired
action but raise no error. This is because the GET response succeeds but since it wasn't a PUT it
doesn't update. See issue: https://github.com/python-gitlab/python-gitlab/issues/1432 2. POST
requests that are redirected also got changed to GET requests. They also caused hard to debug
tracebacks for the user. See issue: https://github.com/python-gitlab/python-gitlab/issues/1477

Correct this by always raising a RedirectError exception and improve the exception message to let
them know what was redirected.

Closes: 1485

Closes: 1432

Closes: 1477

- Stop encoding '.' to '%2E'
([`702e41d`](https://github.com/python-gitlab/python-gitlab/commit/702e41dd0674e76b292d9ea4f559c86f0a99edfe))

Forcing the encoding of '.' to '%2E' causes issues. It also goes against the RFC:
https://datatracker.ietf.org/doc/html/rfc3986.html#section-2.3

From the RFC: For consistency, percent-encoded octets in the ranges of ALPHA (%41-%5A and %61-%7A),
DIGIT (%30-%39), hyphen (%2D), period (%2E), underscore (%5F), or tilde (%7E) should not be
created by URI producers...

Closes 1006 Related 1356 Related 1561

BREAKING CHANGE: stop encoding '.' to '%2E'. This could potentially be a breaking change for users
who have incorrectly configured GitLab servers which don't handle period '.' characters correctly.

- **api**: Delete invalid 'project-runner get' command
([1628](https://github.com/python-gitlab/python-gitlab/pull/1628),
[`905781b`](https://github.com/python-gitlab/python-gitlab/commit/905781bed2afa33634b27842a42a077a160cffb8))

* fix(api): delete 'group-runner get' and 'group-runner delete' commands

Co-authored-by: Léo GATELLIER <gitleogatellier.fr>

- **api**: Replace deprecated attribute in delete_in_bulk()
([1536](https://github.com/python-gitlab/python-gitlab/pull/1536),
[`c59fbdb`](https://github.com/python-gitlab/python-gitlab/commit/c59fbdb0e9311fa84190579769e3c5c6aeb07fe5))

BREAKING CHANGE: The deprecated `name_regex` attribute has been removed in favor of
`name_regex_delete`. (see https://gitlab.com/gitlab-org/gitlab/-/commit/ce99813cf54)

- **build**: Do not include docs in wheel package
([`68a97ce`](https://github.com/python-gitlab/python-gitlab/commit/68a97ced521051afb093cf4fb6e8565d9f61f708))

- **build**: Do not package tests in wheel
([`969dccc`](https://github.com/python-gitlab/python-gitlab/commit/969dccc084e833331fcd26c2a12ddaf448575ab4))

- **objects**: Rename confusing `to_project_id` argument
([`ce4bc0d`](https://github.com/python-gitlab/python-gitlab/commit/ce4bc0daef355e2d877360c6e496c23856138872))

BREAKING CHANGE: rename confusing `to_project_id` argument in transfer_project to `project_id`
(`--project-id` in CLI). This is used for the source project, not for the target namespace.

Chores

- Add .env as a file that search tools should not ignore
([`c9318a9`](https://github.com/python-gitlab/python-gitlab/commit/c9318a9f73c532bee7ba81a41de1fb521ab25ced))

The `.env` file was not set as a file that should not be ignored by search tools. We want to have
the search tools search any `.env` files.

- Add and document optional parameters for get MR
([`bfa3dbe`](https://github.com/python-gitlab/python-gitlab/commit/bfa3dbe516cfa8824b720ba4c52dd05054a855d7))

Add and document (some of the) optional parameters that can be done for a
`project.merge_requests.get()`

Closes 1775

- Add get() methods for GetWithoutIdMixin based classes
([`d27c50a`](https://github.com/python-gitlab/python-gitlab/commit/d27c50ab9d55dd715a7bee5b0c61317f8565c8bf))

Add the get() methods for the GetWithoutIdMixin based classes.

Update the tests/meta/test_ensure_type_hints.py tests to check to ensure that the get methods are
defined with the correct return type.

- Add initial pylint check
([`041091f`](https://github.com/python-gitlab/python-gitlab/commit/041091f37f9ab615e121d5aafa37bf23ef72ba13))

Initial pylint check is added. A LONG list of disabled checks is also added. In the future we should
work through the list and resolve the errors or disable them on a more granular level.

- Add Python 3.11 testing
([`b5ec192`](https://github.com/python-gitlab/python-gitlab/commit/b5ec192157461f7feb326846d4323c633658b861))

Add a unit test for Python 3.11. This will use the latest version of Python 3.11 that is available
from https://github.com/actions/python-versions/

At this time it is 3.11.0-alpha.2 but will move forward over time until the final 3.11 release and
updates. So 3.11.0, 3.11.1, ... will be matched.

- Add running unit tests on windows/macos
([`ad5d60c`](https://github.com/python-gitlab/python-gitlab/commit/ad5d60c305857a8e8c06ba4f6db788bf918bb63f))

Add running the unit tests on windows-latest and macos-latest with Python 3.10.

- Add test case to show branch name with period works
([`ea97d7a`](https://github.com/python-gitlab/python-gitlab/commit/ea97d7a68dd92c6f43dd1f307d63b304137315c4))

Add a test case to show that a branch name with a period can be fetched with a `get()`

Closes: 1715

- Add type hints for gitlab/v4/objects/commits.py
([`dc096a2`](https://github.com/python-gitlab/python-gitlab/commit/dc096a26f72afcebdac380675749a6991aebcd7c))

- Add type-hints to gitlab/v4/objects/epics.py
([`d4adf8d`](https://github.com/python-gitlab/python-gitlab/commit/d4adf8dfd2879b982ac1314e89df76cb61f2dbf9))

- Add type-hints to gitlab/v4/objects/files.py
([`0c22bd9`](https://github.com/python-gitlab/python-gitlab/commit/0c22bd921bc74f48fddd0ff7d5e7525086264d54))

- Add type-hints to gitlab/v4/objects/geo_nodes.py
([`13243b7`](https://github.com/python-gitlab/python-gitlab/commit/13243b752fecc54ba8fc0967ba9a223b520f4f4b))

- Add type-hints to gitlab/v4/objects/groups.py
([`94dcb06`](https://github.com/python-gitlab/python-gitlab/commit/94dcb066ef3ff531778ef4efb97824f010b4993f))

* Add type-hints to gitlab/v4/objects/groups.py * Have share() function update object attributes. *
Add 'get()' method so that type-checkers will understand that getting a group is of type Group.

- Add type-hints to gitlab/v4/objects/issues.py
([`93e39a2`](https://github.com/python-gitlab/python-gitlab/commit/93e39a2947c442fb91f5c80b34008ca1d27cdf71))

- Add type-hints to gitlab/v4/objects/jobs.py
([`e8884f2`](https://github.com/python-gitlab/python-gitlab/commit/e8884f21cee29a0ce4428ea2c4b893d1ab922525))

- Add type-hints to gitlab/v4/objects/labels.py
([`d04e557`](https://github.com/python-gitlab/python-gitlab/commit/d04e557fb09655a0433363843737e19d8e11c936))

- Add type-hints to gitlab/v4/objects/merge_request_approvals.py
([`cf3a99a`](https://github.com/python-gitlab/python-gitlab/commit/cf3a99a0c4cf3dc51e946bf29dc44c21b3be9dac))

- Add type-hints to gitlab/v4/objects/merge_requests.py
([`f9c0ad9`](https://github.com/python-gitlab/python-gitlab/commit/f9c0ad939154375b9940bf41a7e47caab4b79a12))

* Add type-hints to gitlab/v4/objects/merge_requests.py * Add return value to
cancel_merge_when_pipeline_succeeds() function as GitLab docs show it returns a value. * Add
return value to approve() function as GitLab docs show it returns a value. * Add 'get()' method so
that type-checkers will understand that getting a project merge request is of type
ProjectMergeRequest.

- Add type-hints to gitlab/v4/objects/milestones.py
([`8b6078f`](https://github.com/python-gitlab/python-gitlab/commit/8b6078faf02fcf9d966e2b7d1d42722173534519))

- Add type-hints to gitlab/v4/objects/pipelines.py
([`cb3ad6c`](https://github.com/python-gitlab/python-gitlab/commit/cb3ad6ce4e2b4a8a3fd0e60031550484b83ed517))

- Add type-hints to gitlab/v4/objects/repositories.py
([`00d7b20`](https://github.com/python-gitlab/python-gitlab/commit/00d7b202efb3a2234cf6c5ce09a48397a40b8388))

- Add type-hints to gitlab/v4/objects/services.py
([`8da0b75`](https://github.com/python-gitlab/python-gitlab/commit/8da0b758c589f608a6ae4eeb74b3f306609ba36d))

- Add type-hints to gitlab/v4/objects/sidekiq.py
([`a91a303`](https://github.com/python-gitlab/python-gitlab/commit/a91a303e2217498293cf709b5e05930d41c95992))

- Add type-hints to gitlab/v4/objects/snippets.py
([`f256d4f`](https://github.com/python-gitlab/python-gitlab/commit/f256d4f6c675576189a72b4b00addce440559747))

- Add type-hints to gitlab/v4/objects/users.py
([`88988e3`](https://github.com/python-gitlab/python-gitlab/commit/88988e3059ebadd3d1752db60c2d15b7e60e7c46))

Adding type-hints to gitlab/v4/objects/users.py

- Add type-hints to multiple files in gitlab/v4/objects/
([`8b75a77`](https://github.com/python-gitlab/python-gitlab/commit/8b75a7712dd1665d4b3eabb0c4594e80ab5e5308))

Add and/or check type-hints for the following files gitlab.v4.objects.access_requests
gitlab.v4.objects.applications gitlab.v4.objects.broadcast_messages gitlab.v4.objects.deployments
gitlab.v4.objects.keys gitlab.v4.objects.merge_trains gitlab.v4.objects.namespaces
gitlab.v4.objects.pages gitlab.v4.objects.personal_access_tokens
gitlab.v4.objects.project_access_tokens gitlab.v4.objects.tags gitlab.v4.objects.templates
gitlab.v4.objects.triggers

Add a 'get' method with the correct type for Managers derived from GetMixin.

- Add type-hints to setup.py and check with mypy
([`06184da`](https://github.com/python-gitlab/python-gitlab/commit/06184daafd5010ba40bb39a0768540b7e98bd171))

- Attempt to be more informative for missing attributes
([`1839c9e`](https://github.com/python-gitlab/python-gitlab/commit/1839c9e7989163a5cc9a201241942b7faca6e214))

A commonly reported issue from users on Gitter is that they get an AttributeError for an attribute
that should be present. This is often caused due to the fact that they used the `list()` method to
retrieve the object and objects retrieved this way often only have a subset of the full data.

Add more details in the AttributeError message that explains the situation to users. This will
hopefully allow them to resolve the issue.

Update the FAQ in the docs to add a section discussing the issue.

Closes 1138

- Attempt to fix flaky functional test
([`487b9a8`](https://github.com/python-gitlab/python-gitlab/commit/487b9a875a18bb3b4e0d49237bb7129d2c6dba2f))

Add an additional check to attempt to solve the flakiness of the
test_merge_request_should_remove_source_branch() test.

- Check setup.py with mypy
([`77cb7a8`](https://github.com/python-gitlab/python-gitlab/commit/77cb7a8f64f25191d84528cc61e1d246296645c9))

Prior commit 06184daafd5010ba40bb39a0768540b7e98bd171 fixed the type-hints for setup.py. But missed
removing 'setup' from the exclude list in pyproject.toml for mypy checks.

Remove 'setup' from the exclude list in pyproject.toml from mypy checks.

- Clean up install docs
([`a5d8b7f`](https://github.com/python-gitlab/python-gitlab/commit/a5d8b7f2a9cf019c82bef1a166d2dc24f93e1992))

- Convert to using type-annotations for managers
([`d8de4dc`](https://github.com/python-gitlab/python-gitlab/commit/d8de4dc373dc608be6cf6ba14a2acc7efd3fa7a7))

Convert our manager usage to be done via type annotations.

Now to define a manager to be used in a RESTObject subclass can simply do: class
ExampleClass(CRUDMixin, RESTObject): my_manager: MyManager

Any type-annotation that annotates it to be of type *Manager (with the exception of RESTManager)
will cause the manager to be created on the object.

- Correct test_groups.py test
([`9c878a4`](https://github.com/python-gitlab/python-gitlab/commit/9c878a4090ddb9c0ef63d06b57eb0e4926276e2f))

The test was checking twice if the same group3 was not in the returned list. Should have been
checking for group3 and group4.

Also added a test that only skipped one group and checked that the group was not in the returned
list and a non-skipped group was in the list.

- Create a 'tests/meta/' directory and put test_mro.py in it
([`94feb8a`](https://github.com/python-gitlab/python-gitlab/commit/94feb8a5534d43a464b717275846faa75783427e))

The 'test_mro.py' file is not really a unit test but more of a 'meta' check on the validity of the
code base.

- Enable 'warn_redundant_casts' for mypy
([`f40e9b3`](https://github.com/python-gitlab/python-gitlab/commit/f40e9b3517607c95f2ce2735e3b08ffde8d61e5a))

Enable 'warn_redundant_casts'for mypy and resolve one issue.

- Enable mypy for tests/meta/*
([`ba7707f`](https://github.com/python-gitlab/python-gitlab/commit/ba7707f6161463260710bd2b109b172fd63472a1))

- Enable subset of the 'mypy --strict' options that work
([`a86d049`](https://github.com/python-gitlab/python-gitlab/commit/a86d0490cadfc2f9fe5490879a1258cf264d5202))

Enable the subset of the 'mypy --strict' options that work with no changes to the code.

- Enforce type-hints on most files in gitlab/v4/objects/
([`7828ba2`](https://github.com/python-gitlab/python-gitlab/commit/7828ba2fd13c833c118a673bac09b215587ba33b))

* Add type-hints to some of the files in gitlab/v4/objects/ * Fix issues detected when adding
type-hints * Changed mypy exclusion to explicitly list the 13 files that have not yet had
type-hints added.

- Ensure get() methods have correct type-hints
([`46773a8`](https://github.com/python-gitlab/python-gitlab/commit/46773a82565cef231dc3391c12f296ac307cb95c))

Fix classes which don't have correct 'get()' methods for classes derived from GetMixin.

Add a unit test which verifies that classes have the correct return type in their 'get()' method.

- Ensure reset_gitlab() succeeds
([`0aa0b27`](https://github.com/python-gitlab/python-gitlab/commit/0aa0b272a90b11951f900b290a8154408eace1de))

Ensure reset_gitlab() succeeds by waiting to make sure everything has been deleted as expected. If
the timeout is exceeded fail the test.

Not using `wait_for_sidekiq` as it didn't work. During testing I didn't see any sidekiq processes as
being busy even though not everything was deleted.

- Fix functional test failure if config present
([`c8256a5`](https://github.com/python-gitlab/python-gitlab/commit/c8256a5933d745f70c7eea0a7d6230b51bac0fbc))

Fix functional test failure if config present and configured with token.

Closes: 1791

- Fix issue with adding type-hints to 'manager' attribute
([`9a451a8`](https://github.com/python-gitlab/python-gitlab/commit/9a451a892d37e0857af5c82c31a96d68ac161738))

When attempting to add type-hints to the the 'manager' attribute into a RESTObject derived class it
would break things.

This was because our auto-manager creation code would automatically add the specified annotated
manager to the 'manager' attribute. This breaks things.

Now check in our auto-manager creation if our attribute is called 'manager'. If so we ignore it.

- Fix pylint error "expression-not-assigned"
([`a90eb23`](https://github.com/python-gitlab/python-gitlab/commit/a90eb23cb4903ba25d382c37ce1c0839642ba8fd))

Fix pylint error "expression-not-assigned" and remove check from the disabled list.

And I personally think it is much more readable now and is less lines of code.

- Fix renovate setup for gitlab docker image
([`49af15b`](https://github.com/python-gitlab/python-gitlab/commit/49af15b3febda5af877da06c3d8c989fbeede00a))

- Fix type-check issue shown by new requests-types
([`0ee9aa4`](https://github.com/python-gitlab/python-gitlab/commit/0ee9aa4117b1e0620ba3cade10ccb94944754071))

types-requests==2.25.9 changed a type-hint. Update code to handle this change.

- Fix typo in MR documentation
([`2254222`](https://github.com/python-gitlab/python-gitlab/commit/2254222094d218b31a6151049c7a43e19c593a97))

- Fix unit test if config file exists locally
([`c80b3b7`](https://github.com/python-gitlab/python-gitlab/commit/c80b3b75aff53ae228ec05ddf1c1e61d91762846))

Closes 1764

- Generate artifacts for the docs build in the CI
([`85b43ae`](https://github.com/python-gitlab/python-gitlab/commit/85b43ae4a96b72e2f29e36a0aca5321ed78f28d2))

When building the docs store the created documentation as an artifact so that it can be viewed.

This will create a html-docs.zip file which can be downloaded containing the contents of the
`build/sphinx/html/` directory. It can be downloaded, extracted, and then viewed. This can be
useful in reviewing changes to the documentation.

See https://github.com/actions/upload-artifact for more information on how this works.

- Github workflow: cancel prior running jobs on new push
([`fd81569`](https://github.com/python-gitlab/python-gitlab/commit/fd8156991556706f776c508c373224b54ef4e14f))

If new new push is done to a pull-request, then cancel any already running github workflow jobs in
order to conserve resources.

- Have renovate upgrade black version
([1700](https://github.com/python-gitlab/python-gitlab/pull/1700),
[`21228cd`](https://github.com/python-gitlab/python-gitlab/commit/21228cd14fe18897485728a01c3d7103bff7f822))

renovate is not upgrading the `black` package. There is an open issue[1] about this.

Also change .commitlintrc.json to allow 200 character footer lines in the commit message. Otherwise
would be forced to split the URL across multiple lines making it un-clickable :(

Use suggested work-arounds from:
https://github.com/renovatebot/renovate/issues/7167#issuecomment-904106838
https://github.com/scop/bash-completion/blob/e7497f6ee8232065ec11450a52a1f244f345e2c6/renovate.json#L34-L38

[1] https://github.com/renovatebot/renovate/issues/7167

- Improve type-hinting for managers
([`c9b5d3b`](https://github.com/python-gitlab/python-gitlab/commit/c9b5d3bac8f7c1f779dd57653f718dd0fac4db4b))

The 'managers' are dynamically created. This unfortunately means that we don't have any type-hints
for them and so editors which understand type-hints won't know that they are valid attributes.

* Add the type-hints for the managers we define. * Add a unit test that makes sure that the
type-hints and the '_managers' attribute are kept in sync with each other. * Add unit test that
makes sure specified managers in '_managers' have a name ending in 'Managers' to keep with current
convention. * Make RESTObject._managers always present with a default value of None. * Fix a
type-issue revealed now that mypy knows what the type is

- Remove ' type: ignore' for new mypy version
([`34a5f22`](https://github.com/python-gitlab/python-gitlab/commit/34a5f22c81590349645ce7ba46d4153d6de07d8c))

mypy 0.920 now understands the type of 'http.client.HTTPConnection.debuglevel' so we remove the
'type: ignore' comment to make mypy pass

- Remove duplicate/no-op tests from meta/test_ensure_type_hints
([`a2f59f4`](https://github.com/python-gitlab/python-gitlab/commit/a2f59f4e3146b8871a9a1d66ee84295b44321ecb))

Before we were generating 725 tests for the meta/test_ensure_type_hints.py tests. Which isn't a huge
concern as it was fairly fast. But when we had a failure we would usually get two failures for
each problem as the same test was being run multiple times.

Changed it so that: 1. Don't add tests that are not for *Manager classes 2. Use a set so that we
don't have duplicate tests.

After doing that our generated test count in meta/test_ensure_type_hints.py went from 725 to 178
tests.

Additionally removed the parsing of `pyproject.toml` to generate files to ignore as we have finished
adding type-hints to all files in gitlab/v4/objects/. This also means we no longer use the toml
library so remove installation of `types-toml`.

To determine the test count the following command was run: $ tox -e py39 -- -k
test_ensure_type_hints

- Remove pytest-console-scripts specific config
([`e80dcb1`](https://github.com/python-gitlab/python-gitlab/commit/e80dcb1dc09851230b00f8eb63e0c78fda060392))

Remove the pytest-console-scripts specific config from the global '[pytest]' config section.

Use the command line option `--script-launch-mode=subprocess`

Closes 1713

- Rename `master` branch to `main`
([`545f8ed`](https://github.com/python-gitlab/python-gitlab/commit/545f8ed24124837bf4e55aa34e185270a4b7aeff))

BREAKING CHANGE: As of python-gitlab 3.0.0, the default branch for development has changed from
`master` to `main`.

- Run pre-commit on changes to the config file
([`5f10b3b`](https://github.com/python-gitlab/python-gitlab/commit/5f10b3b96d83033805757d72269ad0a771d797d4))

If .pre-commit-config.yaml or .github/workflows/pre_commit.yml are updated then run pre-commit.

- Set pre-commit mypy args to empty list
([`b67a6ad`](https://github.com/python-gitlab/python-gitlab/commit/b67a6ad1f81dce4670f9820750b411facc01a048))

https://github.com/pre-commit/mirrors-mypy/blob/master/.pre-commit-hooks.yaml

Sets some default args which seem to be interfering with things. Plus we set all of our args in the
`pyproject.toml` file.

- Skip a functional test if not using >= py3.9
([`ac9b595`](https://github.com/python-gitlab/python-gitlab/commit/ac9b59591a954504d4e6e9b576b7a43fcb2ddaaa))

One of the tests requires Python 3.9 or higher to run. Mark the test to be skipped if running Python
less than 3.9.

- Update version in docker-compose.yml
([`79321aa`](https://github.com/python-gitlab/python-gitlab/commit/79321aa0e33f0f4bd2ebcdad47769a1a6e81cba8))

When running with docker-compose on Ubuntu 20.04 I got the error:

$ docker-compose up ERROR: The Compose file './docker-compose.yml' is invalid because:

networks.gitlab-network value Additional properties are not allowed ('name' was unexpected)

Changing the version in the docker-compose.yml file fro '3' to '3.5' resolved the issue.

- Use constants from gitlab.const module
([`6b8067e`](https://github.com/python-gitlab/python-gitlab/commit/6b8067e668b6a37a19e07d84e9a0d2d2a99b4d31))

Have code use constants from the gitlab.const module instead of from the top-level gitlab module.

- **api**: Temporarily remove topic delete endpoint
([`e3035a7`](https://github.com/python-gitlab/python-gitlab/commit/e3035a799a484f8d6c460f57e57d4b59217cd6de))

It is not yet available upstream.

- **ci**: Add workflow to lock old issues
([`a7d64fe`](https://github.com/python-gitlab/python-gitlab/commit/a7d64fe5696984aae0c9d6d6b1b51877cc4634cf))

- **ci**: Enable renovate for pre-commit
([`1ac4329`](https://github.com/python-gitlab/python-gitlab/commit/1ac432900d0f87bb83c77aa62757f8f819296e3e))

- **ci**: Wait for all coverage jobs before posting comment
([`c7fdad4`](https://github.com/python-gitlab/python-gitlab/commit/c7fdad42f68927d79e0d1963ade3324370b9d0e2))

- **deps**: Update dependency argcomplete to v2
([`c6d7e9a`](https://github.com/python-gitlab/python-gitlab/commit/c6d7e9aaddda2f39262b695bb98ea4d90575fcce))

- **deps**: Update dependency black to v21
([`5bca87c`](https://github.com/python-gitlab/python-gitlab/commit/5bca87c1e3499eab9b9a694c1f5d0d474ffaca39))

- **deps**: Update dependency black to v21.12b0
([`ab841b8`](https://github.com/python-gitlab/python-gitlab/commit/ab841b8c63183ca20b866818ab2f930a5643ba5f))

- **deps**: Update dependency flake8 to v4
([`79785f0`](https://github.com/python-gitlab/python-gitlab/commit/79785f0bee2ef6cc9872f816a78c13583dfb77ab))

- **deps**: Update dependency isort to v5.10.0
([`ae62468`](https://github.com/python-gitlab/python-gitlab/commit/ae6246807004b84d3b2acd609a70ce220a0ecc21))

- **deps**: Update dependency isort to v5.10.1
([`2012975`](https://github.com/python-gitlab/python-gitlab/commit/2012975ea96a1d3924d6be24aaf92a025e6ab45b))

- **deps**: Update dependency mypy to v0.920
([`a519b2f`](https://github.com/python-gitlab/python-gitlab/commit/a519b2ffe9c8a4bb42d6add5117caecc4bf6ec66))

- **deps**: Update dependency mypy to v0.930
([`ccf8190`](https://github.com/python-gitlab/python-gitlab/commit/ccf819049bf2a9e3be0a0af2a727ab53fc016488))

- **deps**: Update dependency requests to v2.27.0
([`f8c3d00`](https://github.com/python-gitlab/python-gitlab/commit/f8c3d009db3aca004bbd64894a795ee01378cd26))

- **deps**: Update dependency sphinx to v4
([`73745f7`](https://github.com/python-gitlab/python-gitlab/commit/73745f73e5180dd21f450ac4d8cbcca19930e549))

- **deps**: Update dependency sphinx to v4.3.0
([`57283fc`](https://github.com/python-gitlab/python-gitlab/commit/57283fca5890f567626235baaf91ca62ae44ff34))

- **deps**: Update dependency sphinx to v4.3.1
([`93a3893`](https://github.com/python-gitlab/python-gitlab/commit/93a3893977d4e3a3e1916a94293e66373b1458fb))

- **deps**: Update dependency sphinx to v4.3.2
([`2210e56`](https://github.com/python-gitlab/python-gitlab/commit/2210e56da57a9e82e6fd2977453b2de4af14bb6f))

- **deps**: Update dependency types-pyyaml to v5.4.10
([`bdb6cb9`](https://github.com/python-gitlab/python-gitlab/commit/bdb6cb932774890752569ebbc86509e011728ae6))

- **deps**: Update dependency types-pyyaml to v6
([`0b53c0a`](https://github.com/python-gitlab/python-gitlab/commit/0b53c0a260ab2ec2c5ddb12ca08bfd21a24f7a69))

- **deps**: Update dependency types-pyyaml to v6.0.1
([`a544cd5`](https://github.com/python-gitlab/python-gitlab/commit/a544cd576c127ba1986536c9ea32daf2a42649d4))

- **deps**: Update dependency types-requests to v2.25.12
([`205ad5f`](https://github.com/python-gitlab/python-gitlab/commit/205ad5fe0934478eb28c014303caa178f5b8c7ec))

- **deps**: Update dependency types-requests to v2.25.9
([`e3912ca`](https://github.com/python-gitlab/python-gitlab/commit/e3912ca69c2213c01cd72728fd669724926fd57a))

- **deps**: Update dependency types-requests to v2.26.0
([`7528d84`](https://github.com/python-gitlab/python-gitlab/commit/7528d84762f03b668e9d63a18a712d7224943c12))

- **deps**: Update dependency types-requests to v2.26.2
([`ac7e329`](https://github.com/python-gitlab/python-gitlab/commit/ac7e32989a1e7b217b448f57bf2943ff56531983))

- **deps**: Update dependency types-setuptools to v57.4.3
([`ec2c68b`](https://github.com/python-gitlab/python-gitlab/commit/ec2c68b0b41ac42a2bca61262a917a969cbcbd09))

- **deps**: Update pre-commit hook alessandrojcm/commitlint-pre-commit-hook to v6
([`fb9110b`](https://github.com/python-gitlab/python-gitlab/commit/fb9110b1849cea8fa5eddf56f1dbfc1c75f10ad9))

- **deps**: Update pre-commit hook psf/black to v21
([`b86e819`](https://github.com/python-gitlab/python-gitlab/commit/b86e819e6395a84755aaf42334b17567a1bed5fd))

- **deps**: Update pre-commit hook pycqa/flake8 to v4
([`98a5592`](https://github.com/python-gitlab/python-gitlab/commit/98a5592ae7246bf927beb3300211007c0fadba2f))

- **deps**: Update pre-commit hook pycqa/isort to v5.10.1
([`8ac4f4a`](https://github.com/python-gitlab/python-gitlab/commit/8ac4f4a2ba901de1ad809e4fc2fe787e37703a50))

- **deps**: Update python docker tag to v3.10
([`b3d6d91`](https://github.com/python-gitlab/python-gitlab/commit/b3d6d91fed4e5b8424e1af9cadb2af5b6cd8162f))

- **deps**: Update typing dependencies
([`1f95613`](https://github.com/python-gitlab/python-gitlab/commit/1f9561314a880048227b6f3ecb2ed59e60200d19))

- **deps**: Update typing dependencies
([`8d4c953`](https://github.com/python-gitlab/python-gitlab/commit/8d4c95358c9e61c1cfb89562252498093f56d269))

- **deps**: Update typing dependencies
([`4170dbe`](https://github.com/python-gitlab/python-gitlab/commit/4170dbe00112378a523b0fdf3208e8fa4bc5ef00))

- **deps**: Update typing dependencies
([`4eb8ec8`](https://github.com/python-gitlab/python-gitlab/commit/4eb8ec874083adcf86a1781c7866f9dd014f6d27))

- **deps**: Upgrade gitlab-ce to 14.3.2-ce.0
([`5a1678f`](https://github.com/python-gitlab/python-gitlab/commit/5a1678f43184bd459132102cc13cf8426fe0449d))

- **deps**: Upgrade mypy pre-commit hook
([`e19e4d7`](https://github.com/python-gitlab/python-gitlab/commit/e19e4d7cdf9cd04359cd3e95036675c81f4e1dc5))

- **docs**: Link to main, not master
([`af0cb4d`](https://github.com/python-gitlab/python-gitlab/commit/af0cb4d18b8bfbc0624ea2771d73544dc1b24b54))

- **docs**: Load autodoc-typehints module
([`bd366ab`](https://github.com/python-gitlab/python-gitlab/commit/bd366ab9e4b552fb29f7a41564cc180a659bba2f))

- **docs**: Use builtin autodoc hints
([`5e9c943`](https://github.com/python-gitlab/python-gitlab/commit/5e9c94313f6714a159993cefb488aca3326e3e66))

- **objects**: Remove non-existing trigger ownership method
([`8dc7f40`](https://github.com/python-gitlab/python-gitlab/commit/8dc7f40044ce8c478769f25a87c5ceb1aa76b595))

- **tests**: Apply review suggestions
([`381c748`](https://github.com/python-gitlab/python-gitlab/commit/381c748415396e0fe54bb1f41a3303bab89aa065))

Documentation

- Add links to the GitLab API docs
([`e3b5d27`](https://github.com/python-gitlab/python-gitlab/commit/e3b5d27bde3e104e520d976795cbcb1ae792fb05))

Add links to the GitLab API docs for merge_requests.py as it contains code which spans two different
API documentation pages.

- Consolidate changelogs and remove v3 API docs
([`90da8ba`](https://github.com/python-gitlab/python-gitlab/commit/90da8ba0342ebd42b8ec3d5b0d4c5fbb5e701117))

- Correct documentation for updating discussion note
([`ee66f4a`](https://github.com/python-gitlab/python-gitlab/commit/ee66f4a777490a47ad915a3014729a9720bf909b))

Closes 1777

- Correct documented return type
([`acabf63`](https://github.com/python-gitlab/python-gitlab/commit/acabf63c821745bd7e43b7cd3d799547b65e9ed0))

repository_archive() returns 'bytes' not 'str'

https://docs.gitlab.com/ee/api/repositories.html#get-file-archive

Fixes: 1584

- Fix a few typos
([`7ea4ddc`](https://github.com/python-gitlab/python-gitlab/commit/7ea4ddc4248e314998fd27eea17c6667f5214d1d))

There are small typos in: - docs/gl_objects/deploy_tokens.rst - gitlab/base.py - gitlab/mixins.py -
gitlab/v4/objects/features.py - gitlab/v4/objects/groups.py - gitlab/v4/objects/packages.py -
gitlab/v4/objects/projects.py - gitlab/v4/objects/sidekiq.py - gitlab/v4/objects/todos.py

Fixes: - Should read `treatment` rather than `reatment`. - Should read `transferred` rather than
`transfered`. - Should read `registered` rather than `registred`. - Should read `occurred` rather
than `occured`. - Should read `overridden` rather than `overriden`. - Should read `marked` rather
than `maked`. - Should read `instantiate` rather than `instanciate`. - Should read `function`
rather than `fonction`.

- Fix API delete key example
([`b31bb05`](https://github.com/python-gitlab/python-gitlab/commit/b31bb05c868793e4f0cb4573dad6bf9ca01ed5d9))

- Only use type annotations for documentation
([`b7dde0d`](https://github.com/python-gitlab/python-gitlab/commit/b7dde0d7aac8dbaa4f47f9bfb03fdcf1f0b01c41))

- Rename documentation files to match names of code files
([`ee3f865`](https://github.com/python-gitlab/python-gitlab/commit/ee3f8659d48a727da5cd9fb633a060a9231392ff))

Rename the merge request related documentation files to match the code files. This will make it
easier to find the documentation quickly.

Rename: `docs/gl_objects/mrs.rst -> `docs/gl_objects/merge_requests.rst`
`docs/gl_objects/mr_approvals.rst -> `docs/gl_objects/merge_request_approvals.rst`

- Switch to Furo and refresh introduction pages
([`ee6b024`](https://github.com/python-gitlab/python-gitlab/commit/ee6b024347bf8a178be1a0998216f2a24c940cee))

- Update docs to use gitlab.const for constants
([`b3b0b5f`](https://github.com/python-gitlab/python-gitlab/commit/b3b0b5f1da5b9da9bf44eac33856ed6eadf37dd6))

Update the docs to use gitlab.const to access constants.

- Use annotations for return types
([`79e785e`](https://github.com/python-gitlab/python-gitlab/commit/79e785e765f4219fe6001ef7044235b82c5e7754))

- **api**: Clarify job token usage with auth()
([`3f423ef`](https://github.com/python-gitlab/python-gitlab/commit/3f423efab385b3eb1afe59ad12c2da7eaaa11d76))

See issue 1620

- **api**: Document the update method for project variables
([`7992911`](https://github.com/python-gitlab/python-gitlab/commit/7992911896c62f23f25742d171001f30af514a9a))

- **pipelines**: Document take_ownership method
([`69461f6`](https://github.com/python-gitlab/python-gitlab/commit/69461f6982e2a85dcbf95a0b884abd3f4050c1c7))

- **project**: Remove redundant encoding parameter
([`fed613f`](https://github.com/python-gitlab/python-gitlab/commit/fed613f41a298e79a975b7f99203e07e0f45e62c))

Features

- Add delete on package_file object
([`124667b`](https://github.com/python-gitlab/python-gitlab/commit/124667bf16b1843ae52e65a3cc9b8d9235ff467e))

- Add support for `projects.groups.list()`
([`68ff595`](https://github.com/python-gitlab/python-gitlab/commit/68ff595967a5745b369a93d9d18fef48b65ebedb))

Add support for `projects.groups.list()` endpoint.

Closes 1717

- Add support for `squash_option` in Projects
([`a246ce8`](https://github.com/python-gitlab/python-gitlab/commit/a246ce8a942b33c5b23ac075b94237da09013fa2))

There is an optional `squash_option` parameter which can be used when creating Projects and
UserProjects.

Closes 1744

- Allow global retry_transient_errors setup
([`3b1d3a4`](https://github.com/python-gitlab/python-gitlab/commit/3b1d3a41da7e7228f3a465d06902db8af564153e))

`retry_transient_errors` can now be set through the Gitlab instance and global configuration

Documentation for API usage has been updated and missing tests have been added.

- Default to gitlab.com if no URL given
([`8236281`](https://github.com/python-gitlab/python-gitlab/commit/823628153ec813c4490e749e502a47716425c0f1))

BREAKING CHANGE: python-gitlab will now default to gitlab.com if no URL is given

- Remove support for Python 3.6, require 3.7 or higher
([`414009d`](https://github.com/python-gitlab/python-gitlab/commit/414009daebe19a8ae6c36f050dffc690dff40e91))

Python 3.6 is End-of-Life (EOL) as of 2021-12 as stated in https://www.python.org/dev/peps/pep-0494/

By dropping support for Python 3.6 and requiring Python 3.7 or higher it allows python-gitlab to
take advantage of new features in Python 3.7, which are documented at:
https://docs.python.org/3/whatsnew/3.7.html

Some of these new features that may be useful to python-gitlab are: * PEP 563, postponed evaluation
of type annotations. * dataclasses: PEP 557 – Data Classes * importlib.resources * PEP 562,
customization of access to module attributes. * PEP 560, core support for typing module and
generic types. * PEP 565, improved DeprecationWarning handling

BREAKING CHANGE: As of python-gitlab 3.0.0, Python 3.6 is no longer supported. Python 3.7 or higher
is required.

- **api**: Add merge request approval state
([`f41b093`](https://github.com/python-gitlab/python-gitlab/commit/f41b0937aec5f4a5efba44155cc2db77c7124e5e))

Add support for merge request approval state

- **api**: Add merge trains
([`fd73a73`](https://github.com/python-gitlab/python-gitlab/commit/fd73a738b429be0a2642d5b777d5e56a4c928787))

Add support for merge trains

- **api**: Add project label promotion
([`6d7c88a`](https://github.com/python-gitlab/python-gitlab/commit/6d7c88a1fe401d271a34df80943634652195b140))

Adds a mixin that allows the /promote endpoint to be called.

Signed-off-by: Raimund Hook <raimund.hookexfo.com>

- **api**: Add project milestone promotion
([`f068520`](https://github.com/python-gitlab/python-gitlab/commit/f0685209f88d1199873c1f27d27f478706908fd3))

Adds promotion to Project Milestones

Signed-off-by: Raimund Hook <raimund.hookexfo.com>

- **api**: Add support for epic notes
([`7f4edb5`](https://github.com/python-gitlab/python-gitlab/commit/7f4edb53e9413f401c859701d8c3bac4a40706af))

Added support for notes on group epics

Signed-off-by: Raimund Hook <raimund.hookexfo.com>

- **api**: Add support for Topics API
([`e7559bf`](https://github.com/python-gitlab/python-gitlab/commit/e7559bfa2ee265d7d664d7a18770b0a3e80cf999))

- **api**: Support file format for repository archive
([`83dcabf`](https://github.com/python-gitlab/python-gitlab/commit/83dcabf3b04af63318c981317778f74857279909))

- **build**: Officially support and test python 3.10
([`c042ddc`](https://github.com/python-gitlab/python-gitlab/commit/c042ddc79ea872fc8eb8fe4e32f4107a14ffed2d))

- **cli**: Allow options from args and environment variables
([`ca58008`](https://github.com/python-gitlab/python-gitlab/commit/ca58008607385338aaedd14a58adc347fa1a41a0))

BREAKING-CHANGE: The gitlab CLI will now accept CLI arguments

and environment variables for its global options in addition to configuration file options. This may
change behavior for some workflows such as running inside GitLab CI and with certain environment
variables configured.

- **cli**: Do not require config file to run CLI
([`92a893b`](https://github.com/python-gitlab/python-gitlab/commit/92a893b8e230718436582dcad96175685425b1df))

BREAKING CHANGE: A config file is no longer needed to run the CLI. python-gitlab will default to
https://gitlab.com with no authentication if there is no config file provided. python-gitlab will
now also only look for configuration in the provided PYTHON_GITLAB_CFG path, instead of merging it
with user- and system-wide config files. If the environment variable is defined and the file
cannot be opened, python-gitlab will now explicitly fail.

- **docker**: Remove custom entrypoint from image
([`80754a1`](https://github.com/python-gitlab/python-gitlab/commit/80754a17f66ef4cd8469ff0857e0fc592c89796d))

This is no longer needed as all of the configuration is handled by the CLI and can be passed as
arguments.

- **objects**: List starred projects of a user
([`47a5606`](https://github.com/python-gitlab/python-gitlab/commit/47a56061421fc8048ee5cceaf47ac031c92aa1da))

- **objects**: Support Create and Revoke personal access token API
([`e19314d`](https://github.com/python-gitlab/python-gitlab/commit/e19314dcc481b045ba7a12dd76abedc08dbdf032))

- **objects**: Support delete package files API
([`4518046`](https://github.com/python-gitlab/python-gitlab/commit/45180466a408cd51c3ea4fead577eb0e1f3fe7f8))

Refactoring

- Deprecate accessing constants from top-level namespace
([`c0aa0e1`](https://github.com/python-gitlab/python-gitlab/commit/c0aa0e1c9f7d7914e3062fe6503da870508b27cf))

We are planning on adding enumerated constants into gitlab/const.py, but if we do that than they
will end up being added to the top-level gitlab namespace. We really want to get users to start
using `gitlab.const.` to access the constant values in the future.

Add the currently defined constants to a list that should not change. Use a module level __getattr__
function so that we can deprecate access to the top-level constants.

Add a unit test which verifies we generate a warning when accessing the top-level constants.

- Use f-strings for string formatting
([`7925c90`](https://github.com/python-gitlab/python-gitlab/commit/7925c902d15f20abaecdb07af213f79dad91355b))

- Use new-style formatting for named placeholders
([`c0d8810`](https://github.com/python-gitlab/python-gitlab/commit/c0d881064f7c90f6a510db483990776ceb17b9bd))

- **objects**: Remove deprecated branch protect methods
([`9656a16`](https://github.com/python-gitlab/python-gitlab/commit/9656a16f9f34a1aeb8ea0015564bad68ffb39c26))

BREAKING CHANGE: remove deprecated branch protect methods in favor of the more complete protected
branches API.

- **objects**: Remove deprecated constants defined in objects
([`3f320af`](https://github.com/python-gitlab/python-gitlab/commit/3f320af347df05bba9c4d0d3bdb714f7b0f7b9bf))

BREAKING CHANGE: remove deprecated constants defined in gitlab.v4.objects, and use only gitlab.const
module

- **objects**: Remove deprecated members.all() method
([`4d7b848`](https://github.com/python-gitlab/python-gitlab/commit/4d7b848e2a826c58e91970a1d65ed7d7c3e07166))

BREAKING CHANGE: remove deprecated members.all() method in favor of members_all.list()

- **objects**: Remove deprecated pipelines() method
([`c4f5ec6`](https://github.com/python-gitlab/python-gitlab/commit/c4f5ec6c615e9f83d533a7be0ec19314233e1ea0))

BREAKING CHANGE: remove deprecated pipelines() methods in favor of pipelines.list()

- **objects**: Remove deprecated project.issuesstatistics
([`ca7777e`](https://github.com/python-gitlab/python-gitlab/commit/ca7777e0dbb82b5d0ff466835a94c99e381abb7c))

BREAKING CHANGE: remove deprecated project.issuesstatistics in favor of project.issues_statistics

- **objects**: Remove deprecated tag release API
([`2b8a94a`](https://github.com/python-gitlab/python-gitlab/commit/2b8a94a77ba903ae97228e7ffa3cc2bf6ceb19ba))

BREAKING CHANGE: remove deprecated tag release API. This was removed in GitLab 14.0

Testing

- Drop httmock dependency in test_gitlab.py
([`c764bee`](https://github.com/python-gitlab/python-gitlab/commit/c764bee191438fc4aa2e52d14717c136760d2f3f))

- Reproduce missing pagination headers in tests
([`501f9a1`](https://github.com/python-gitlab/python-gitlab/commit/501f9a1588db90e6d2c235723ba62c09a669b5d2))

- **api**: Fix current user mail count in newer gitlab
([`af33aff`](https://github.com/python-gitlab/python-gitlab/commit/af33affa4888fa83c31557ae99d7bbd877e9a605))

- **build**: Add smoke tests for sdist & wheel package
([`b8a47ba`](https://github.com/python-gitlab/python-gitlab/commit/b8a47bae3342400a411fb9bf4bef3c15ba91c98e))

- **cli**: Improve basic CLI coverage
([`6b892e3`](https://github.com/python-gitlab/python-gitlab/commit/6b892e3dcb18d0f43da6020b08fd4ba891da3670))

2.40.0

They needed to be updated together as just updating `black` caused a dependency conflict.

Updated files by running `black` and committing the changes.

- **deps**: Update dependency coverage to v7
([2501](https://github.com/python-gitlab/python-gitlab/pull/2501),
[`aee73d0`](https://github.com/python-gitlab/python-gitlab/commit/aee73d05c8c9bd94fb7f01dfefd1bb6ad19c4eb2))

Co-authored-by: renovate[bot] <29139614+renovate[bot]users.noreply.github.com>

- **deps**: Update dependency flake8 to v6
([2502](https://github.com/python-gitlab/python-gitlab/pull/2502),
[`3d4596e`](https://github.com/python-gitlab/python-gitlab/commit/3d4596e8cdebbc0ea214d63556b09eac40d42a9c))

Co-authored-by: renovate[bot] <29139614+renovate[bot]users.noreply.github.com>

- **deps**: Update dependency furo to v2023
([`7a1545d`](https://github.com/python-gitlab/python-gitlab/commit/7a1545d52ed0ac8e2e42a2f260e8827181e94d88))

- **deps**: Update dependency pre-commit to v3
([2508](https://github.com/python-gitlab/python-gitlab/pull/2508),
[`7d779c8`](https://github.com/python-gitlab/python-gitlab/commit/7d779c85ffe09623c5d885b5a429b0242ad82f93))

Co-authored-by: renovate[bot] <29139614+renovate[bot]users.noreply.github.com>

- **deps**: Update mypy (1.0.0) and responses (0.22.0)
([`9c24657`](https://github.com/python-gitlab/python-gitlab/commit/9c2465759386b60a478bd8f43e967182ed97d39d))

Update the `requirements-*` files.

In order to update mypy==1.0.0 we need to also update responses==0.22.0

Fix one issue found by `mypy`

Leaving updates for `precommit` to be done in a separate commit by someone.

- **deps**: Update pre-commit hook psf/black to v23
([`217a787`](https://github.com/python-gitlab/python-gitlab/commit/217a78780c3ae6e41fb9d76d4d841c5d576de45f))

- **github**: Add default pull request template
([`bf46c67`](https://github.com/python-gitlab/python-gitlab/commit/bf46c67db150f0657b791d94e6699321c9985f57))

- **pre-commit**: Bumping versions
([`e973729`](https://github.com/python-gitlab/python-gitlab/commit/e973729e007f664aa4fde873654ef68c21be03c8))

- **renovate**: Bring back custom requirements pattern
([`ae0b21c`](https://github.com/python-gitlab/python-gitlab/commit/ae0b21c1c2b74bf012e099ae1ff35ce3f40c6480))

- **renovate**: Do not ignore tests dir
([`5b8744e`](https://github.com/python-gitlab/python-gitlab/commit/5b8744e9c2241e0fdcdef03184afcb48effea90f))

- **renovate**: Swith to gitlab-ee
([`8da48ee`](https://github.com/python-gitlab/python-gitlab/commit/8da48ee0f32c293b4788ebd0ddb24018401ef7ad))

- **setup**: Depend on typing-extensions for 3.7 until EOL
([`3abc557`](https://github.com/python-gitlab/python-gitlab/commit/3abc55727d4d52307b9ce646fee172f94f7baf8d))

Documentation

- Fix update badge behaviour
([`3d7ca1c`](https://github.com/python-gitlab/python-gitlab/commit/3d7ca1caac5803c2e6d60a3e5eba677957b3cfc6))

docs: fix update badge behaviour

Earlier: badge.image_link = new_link

Now: badge.image_url = new_image_url badge.link_url = new_link_url

- **advanced**: Clarify netrc, proxy behavior with requests
([`1da7c53`](https://github.com/python-gitlab/python-gitlab/commit/1da7c53fd3476a1ce94025bb15265f674af40e1a))

- **advanced**: Fix typo in Gitlab examples
([`1992790`](https://github.com/python-gitlab/python-gitlab/commit/19927906809c329788822f91d0abd8761a85c5c3))

- **objects**: Fix typo in pipeline schedules
([`3057f45`](https://github.com/python-gitlab/python-gitlab/commit/3057f459765d1482986f2086beb9227acc7fd15f))

Features

- Add resource_weight_event for ProjectIssue
([`6e5ef55`](https://github.com/python-gitlab/python-gitlab/commit/6e5ef55747ddeabe6d212aec50d66442054c2352))

- **backends**: Use PEP544 protocols for structural subtyping
([2442](https://github.com/python-gitlab/python-gitlab/pull/2442),
[`4afeaff`](https://github.com/python-gitlab/python-gitlab/commit/4afeaff0361a966254a7fbf0120e93583d460361))

The purpose of this change is to track API changes described in
https://github.com/python-gitlab/python-gitlab/blob/main/docs/api-levels.rst, for example, for
package versioning and breaking change announcements in case of protocol changes.

This is MVP implementation to be used by 2435.

- **cli**: Add setting of `allow_force_push` for protected branch
([`929e07d`](https://github.com/python-gitlab/python-gitlab/commit/929e07d94d9a000e6470f530bfde20bb9c0f2637))

For the CLI: add `allow_force_push` as an optional argument for creating a protected branch.

API reference: https://docs.gitlab.com/ee/api/protected_branches.html#protect-repository-branches

Closes: 2466

- **client**: Add http_patch method
([2471](https://github.com/python-gitlab/python-gitlab/pull/2471),
[`f711d9e`](https://github.com/python-gitlab/python-gitlab/commit/f711d9e2bf78f58cee6a7c5893d4acfd2f980397))

In order to support some new API calls we need to support the HTTP `PATCH` method.

Closes: 2469

- **objects**: Support fetching PATs via id or `self` endpoint
([`19b38bd`](https://github.com/python-gitlab/python-gitlab/commit/19b38bd481c334985848be204eafc3f1ea9fe8a6))

- **projects**: Allow importing additional items from GitHub
([`ce84f2e`](https://github.com/python-gitlab/python-gitlab/commit/ce84f2e64a640e0d025a7ba3a436f347ad25e88e))

Refactoring

- **client**: Let mypy know http_password is set
([`2dd177b`](https://github.com/python-gitlab/python-gitlab/commit/2dd177bf83fdf62f0e9bdcb3bc41d5e4f5631504))

Testing

- **functional**: Clarify MR fixture factory name
([`d8fd1a8`](https://github.com/python-gitlab/python-gitlab/commit/d8fd1a83b588f4e5e61ca46a28f4935220c5b8c4))

- **meta**: Move meta suite into unit tests
([`847004b`](https://github.com/python-gitlab/python-gitlab/commit/847004be021b4a514e41bf28afb9d87e8643ddba))

They're always run with it anyway, so it makes no difference.

- **unit**: Consistently use inline fixtures
([`1bc56d1`](https://github.com/python-gitlab/python-gitlab/commit/1bc56d164a7692cf3aaeedfa1ed2fb869796df03))

- **unit**: Increase V4 CLI coverage
([`5748d37`](https://github.com/python-gitlab/python-gitlab/commit/5748d37365fdac105341f94eaccde8784d6f57e3))

- **unit**: Remove redundant package
([`4a9e3ee`](https://github.com/python-gitlab/python-gitlab/commit/4a9e3ee70f784f99f373f2fddde0155649ebe859))

- **unit**: Split the last remaining unittest-based classes into modules"
([`14e0f65`](https://github.com/python-gitlab/python-gitlab/commit/14e0f65a3ff05563df4977d792272f8444bf4312))

Page 8 of 13

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.