Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Poetry pip shims fix and dropping py3.7 in the same release breaks isort on py3.7 without recourse #2083

Closed
vedantpuri opened this issue Jan 29, 2023 · 12 comments · Fixed by Ekumen-OS/tortoise-data-migration#43 or psf/requests#6370

Comments

@vedantpuri
Copy link

The following PRs were bundled in 5.12.0

If I understand this correctly, anyone using isort on py3.7 does not get the poetry fix. Should there have been an intermediary release before 5.12.0 to cover this case ?

@sijunhe
Copy link

sijunhe commented Jan 29, 2023

+1 to this. We are also in the same dilemma. Would it be possible to do another release that fixes isort for py3.7?

@noorul
Copy link

noorul commented Jan 30, 2023

Looks like the release 5.12.0 has dropped support for 3.7 and this has put everyone using < 3.8 in dilemma.

@psdon
Copy link

psdon commented Jan 30, 2023

This also affects python 3.11

@exhuma
Copy link

exhuma commented Jan 30, 2023

It also seems to affect Python 3.10

We have over 100 projects, each of which with their own .pre-commit-config.yml with daily dev-builds configured. This caused a ton of error-notifications being generated this morning.

Updating all of the projects would be pretty cumbersome. But without a fix we'll be confronted with the same notification mess tomorrow (and each day after).

We can mitigate this by pinning an isort version in a centrally shared part of the pipeline. But that's pretty hacky and I would appreciate a fix by isort considering that this has been affecting a lot of people.

@RobPasMue
Copy link

This also affects python 3.11

We are having issues throughout many repositories because of this problem as well on Python 3.11...

@timothycrosley
Copy link
Member

timothycrosley commented Jan 30, 2023

@psdon @exhuma and @RobPasMue Can you confirm you are using the latest version of isort (5.12.0)? This issue should be fixed in that release, but is bundled with the project deprecating support for Python3.7. I was planning on making a hot fix for 3.7 with the workaround for the surprising breaking change from poetry, but if this is still happening with the fix in place on those newer versions more investigation will be needed. Is is possible all these Python3.10/3.11 projects have the old version of isort pinned, or need to run a pre-commit autoupdate? If that's the case there's nothing I could do at the isort level to fix that, since any changes I make will be new releases.

@RobPasMue
Copy link

That's true, I was pointing to 5.11.4 while using Python 3.11 - thanks for pointing it out @timothycrosley! That solved our issues =)

@exhuma
Copy link

exhuma commented Jan 30, 2023

@timothycrosley The projects are not running on isort 5.12 and updating all of the projects is not feasible. There just are too many and we cannot drop everything right now to work on this. It's too time intensive. We need to go through all the failures, check out the code, run autoupdate commit and push for over 100 projects.

Running autoupdate can also have unintended side effects as it updates everything. We've had surprising failures in the past with projects like mypy when it suddenly started detecting new type-errors in newer versions. We just cannot risk running this "blindly" on every project.

This will be done, but we cannot do this quickly enough and I prefer to do this in a calm, controlled space.

We have a shared CI pipeline which gives me some flexibility but the nature of pre-commit is that the config is inside the project. So each project needs to be touched individually.

The quickest thing we can do is to disable isort everywhere. But I'm working on a more invasive solution which would not require us to drop isort. I will share it as soon as it's done (which is soon) ;)

@timothycrosley
Copy link
Member

timothycrosley commented Jan 30, 2023

@exhuma best of luck on your approach to fix this! I really wish there was a way for me to safely retroactively fix the old release, but it simply isn't possible. The only project that could fix it for existing references to the old version would be the poetry project, where the incompatibility was introduced

@exhuma
Copy link

exhuma commented Jan 30, 2023

Here is a script that I will shim into our shared pipeline runs. It's far from ideal, but it allows us to go through our projects piece by piece while keeping the pipelines "green". For anyone else who needs this, feel free to use it.

This script replaces all isort references with 5.12.0. So even newer versions of isort would be "downgraded" which is pretty bad. But it's a workaround.

#!/usr/bin/env python
"""
Fix for https://github.com/PyCQA/isort/issues/2083

This script *modifies* ``.pre-commit-config.yaml`` and pins the isort version
to 5.12.0

This is a hacky workaround for the aforementioned GitHub issue. Considering
that this aggressively changes the revision number for ``isort`` this should
only be used as a workaround if no other solution is available.

It should also be removed as soon as it is no longer needed because this will
"undo" any upgrades to ``isort`` in repositories.

This script assumes to be run in a CI-pipeline. As such, it also assumes that
it can modify files with impunity as they will not be committed back to the
source-code and will be lost after CI pipeline cleanup. This is - in this case
- the intended behaviour.



--- LICENSE ------------------------------------------------------------------

Copyright 2023 Michel Albert

Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
of the Software, and to permit persons to whom the Software is furnished to do
so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
"""

from copy import deepcopy
from os.path import exists
from shutil import copyfile
from textwrap import dedent

from yaml import dump, safe_load

import yamlfix.services

source_file = ".pre-commit-config.yaml"
backup_file = f"{source_file}.bak"

if exists(backup_file):
    raise FileExistsError(f"File {backup_file} already exists")

copyfile(source_file, backup_file)

with open(source_file, encoding="utf8") as fptr:
    content = safe_load(fptr)

replacement_done = False
for repo in content.get("repos", []):
    if repo["repo"] == "https://github.com/PyCQA/isort" and not repo["rev"].startswith(
        "5.12"
    ):
        original = deepcopy(repo)
        repo["rev"] = "5.12.0"
        template = dedent(
            f"""\
            !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
                Problematic isort version {original["rev"]} detected
            !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
            Replacing with pinned 5.12.0
            This is a *temporary* fix. For more information see

            https://github.com/PyCQA/isort/issues/2083
            ----------------------------------------------------------------
            Original Config
            {{original}}
            ----------------------------------------------------------------
            New Config
            {{new}}
            !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
            """
        )
        print(
            template.format(
                original=yamlfix.fix_code(dump(original)),
                new=yamlfix.fix_code(dump(repo)),
            )
        )
        print(f"Updating {repo} with pinned isort version")
        print(f"Updated to {repo}")
        replacement_done = True

with open(source_file, "w", encoding="utf8") as fptr:
    output = yamlfix.services.fix_code(dump(content))
    fptr.write(output)

@exhuma
Copy link

exhuma commented Jan 30, 2023

The only project that could fix it for existing references to the old version would be the poetry project, where the incompatibility was introduced

Any change to prod the poetry devs for this? As a member of the isort project you would surely have more weight than myself 😉

@timothycrosley
Copy link
Member

Closing this as I've fixed this for 3.7 as well with a hotfix: 5.11.5

@timothycrosley timothycrosley pinned this issue Jan 30, 2023
aiven-anton added a commit to Aiven-Open/karapace that referenced this issue Jan 30, 2023
CI is broken on main due to this isort issue, the root cause lies in an
underlying incompatible change in Poetry.

PyCQA/isort#2083
aiven-anton added a commit to Aiven-Open/karapace that referenced this issue Jan 30, 2023
CI is broken on main due to this isort issue, the root cause lies in an
underlying incompatible change in Poetry.

PyCQA/isort#2083

With the upgrade to flake8 6, we ran into an issue with comments in the
configuration file. Those comments are moved to their own lines above
the config instead, see issue below.

PyCQA/flake8#1756
aiven-anton added a commit to Aiven-Open/karapace that referenced this issue Jan 30, 2023
CI is broken on main due to this isort issue, the root cause lies in an
underlying incompatible change in Poetry. The new version of isort has
dropped support for Python 3.7 so we bump CI to run on 3.11 instead (3.7
is EOL later this year anyway).

PyCQA/isort#2083

With the upgrade to flake8 6, we ran into an issue with comments in the
configuration file. Those comments are moved to their own lines above
the config instead, see issue below.

PyCQA/flake8#1756
aiven-anton added a commit to Aiven-Open/karapace that referenced this issue Jan 30, 2023
CI is broken on main due to this isort issue, the root cause lies in an
underlying incompatible change in Poetry. The new version of isort has
dropped support for Python 3.7 so we bump CI to run on 3.11 instead (3.7
is EOL later this year anyway).

PyCQA/isort#2083

With the upgrade to flake8 6, we ran into an issue with comments in the
configuration file. Those comments are moved to their own lines above
the config instead, see issue below.

PyCQA/flake8#1756

Because of installation issues in the lint step, installation is altered
to only installed pre-commit which handles its own dependencies anyway.
connelldave pushed a commit to connelldave/botocove that referenced this issue Feb 8, 2023
See [CI error][1]:

```text
RuntimeError: The Poetry configuration is invalid:
  - [extras.pipfile_deprecated_finder.2] 'pip-shims<=0.3.4' does not match '^[a-zA-Z-_.0-9]+$'
```

See [isort issues referencing `pip-shims`](PyCQA/isort#2083) for more details.

[1]: https://github.com/connelldave/botocove/actions/runs/4120906018/jobs/7116097629
LucidDan added a commit to LucidDan/asgiref that referenced this issue Feb 18, 2023
Update isort to 5.11.5 due to PyCQA/isort#2083
Note 5.12.0 is out but has already dropped support for python 3.7
andrewgodwin pushed a commit to django/asgiref that referenced this issue Feb 19, 2023
Update isort to 5.11.5 due to PyCQA/isort#2083
Note 5.12.0 is out but has already dropped support for python 3.7
LucidDan added a commit to LucidDan/asgiref that referenced this issue Feb 19, 2023
Update isort to 5.11.5 due to PyCQA/isort#2083
Note 5.12.0 is out but has already dropped support for python 3.7
honggyukim added a commit to honggyukim/uftrace that referenced this issue Feb 20, 2023
The pre-commit shows an error in isort hook as follows.

  RuntimeError: The Poetry configuration is invalid

This can be fixed by upgrading isort rev to 5.11.5 so this patch changes
the version to fix it.

In addition, apply changes from isort 5.11.5 to make pre-commit happy.

Link: PyCQA/isort#2083 (comment)
Signed-off-by: Honggyu Kim <[email protected]>
honggyukim added a commit to namhyung/uftrace that referenced this issue Feb 20, 2023
The pre-commit shows an error in isort hook as follows.

  RuntimeError: The Poetry configuration is invalid

This can be fixed by upgrading isort rev to 5.11.5 so this patch changes
the version to fix it.

In addition, apply changes from isort 5.11.5 to make pre-commit happy.

Link: PyCQA/isort#2083 (comment)
Signed-off-by: Honggyu Kim <[email protected]>
yetinam added a commit to seisbench/seisbench that referenced this issue Feb 20, 2023
HorlogeSkynet added a commit to python-distro/distro that referenced this issue Feb 20, 2023
datalogics-robb pushed a commit to datalogics-robb/conan-center-index that referenced this issue Mar 6, 2023
Bumping to isort 5.11.5 fixes a bug with Poetry.

See this comment: PyCQA/isort#2083 (comment)
goldentroll added a commit to goldentroll/asgiref that referenced this issue Mar 14, 2023
Update isort to 5.11.5 due to PyCQA/isort#2083
Note 5.12.0 is out but has already dropped support for python 3.7
bpedersen2 pushed a commit to mlz-ictrl/nicos that referenced this issue Mar 27, 2023
isort v5.10.1 present compatibility issues in some environments (see
PyCQA/isort#2083 (comment)).
isort v5.12.0 seems to solve the issue.

Change-Id: Ie0d10567a9d281b211ef47f50acdd53ab55e9b6f
Reviewed-on: https://forge.frm2.tum.de/review/c/frm2/nicos/nicos/+/30758
Tested-by: Jenkins Automated Tests <[email protected]>
Reviewed-by: Jonas Petersson <[email protected]>
Reviewed-by: Jens Krueger <[email protected]>
zoj613 added a commit to zoj613/aehmc that referenced this issue May 3, 2023
Setting up the pre-commit hooks fails due to a bug in isort (see:
PyCQA/isort#2083). This commit updates the
version to 5.12.0 where this bug was fixed.
zoj613 added a commit to zoj613/aehmc that referenced this issue May 3, 2023
Setting up the pre-commit hooks fails due to a bug in isort (see:
PyCQA/isort#2083). This commit updates the
version to 5.12.0 where this bug was fixed.
brinkflew pushed a commit to odoo-odev/odev that referenced this issue Sep 19, 2024
[REM] *: remove erroneous symbolic link

[IMP] clean: force password = 'odoo' for all users except admin

[FIX] listing: remove typo in column titles

[REF] cleanup setup file

- Add utils.mkdir method
- Refactor src/setup.py to use mkdir instead of rpeating the same actions four times

[REF] refactor scripts

- Rename  to
- New methods to ensure a database is running or stopped
- Save config to file while running commands
- Small fixes and improvements

[ADD] new scripts

- [#3] Dump a SaaS database
- Initialize an empty database
- Kill the process of a running database
- [#5] Quickstart the generation of a new database (create, init/dump/restore, clean)
- Small improvements in scripts

[IMP] update documentation

[FIX] subprocess command for restoring dumpfiles

[FIX] default permissions for created directories

[FIX #1] *: standard python libraries in requirements

[FIX] reference errors in setup

[IMP] automatically create configuration file if not existing

[IMP] create: duplicate database from template

[IMP] init: prevent loading demo data

[IMP] setup: move settings to user config by default

[FIX] scripts: path to local config

[IMP] run: add support for virtualenv

[FIX] run: typo in message to user

[IMP] utils: print carets in bold

[IMP] utils: code formatting

[IMP] scripts: remove support for virtualenv as it is user and system-specific

[IMP] *: code formatting

[IMP] dump: download dumps of SH databases

[ADD] task: get the link to a task

[FIX] quickstart: init empty database with version number

[FIX] readme: remove sudo during install

[IMP] scripts: add virtualenv support

- Create virtualenv linked to odoo version
- Switch to correct virtualenv when running odoo-bin
- Automatically install requirements in the correct virtualenv
- improve checking for changes in Odoo's GitHub repositories

[ADD] help: display help about subcommands

[README] update setup after repository transfer

[IMP] add sql queries to clean script

[IMP] uncomment query to disable oauth providers

[PERF] faster db list

[IMP] always add current directory if addon directory

[ADD] cli: imported module from `psbe-custom-upgrade` PR #17

[IMP] cli: refactored and added sub-subcommands feature

[REF] global refactoring, adapted scripts to `cli` interface

[IMP] allowing databases with slightly more exotic names

[FIX] fixed multiline argparse formatting

[FIX] `cli` refactoring testing fixes

[IMP] run: made addons argument optional

[FIX] restore: fixed and refactored pg import / zip handling code

[FIX] quickstart: fixed refactoring bugs, sql dumps, url regex

[IMP] cli: short help feature in CliCommand, filled in for commands

[FIX] cli: fixed root / subroots not running __init_subclass__

[FIX] __main__: relative imports when run from symlink

[FIX] quickstart: fixed url regex

[FIX] __main__: exceptions TODO, check ret code vs. log level on exit

[FIX] kill: removed duplicate/unused `pid` re-assignment

[REF] *: removed NO_DB, refactored `template1` methods in base class

[FIX] *: AVS PR review, TODOs, typos, small tweaks and fixes

[REF] *: refactored sql classes code and interface

[REF] utils: clearer `curl` function signature for response headers

[FIX] *: clear database cache when altering databases

[FIX] create: adapted to new `dbname_validate` approach for template

[IMP] added requirements.txt file

[REF] *: substituted `clint` lib with `blessed`, logging with stdlib

[REF] *: renamed package `src` to `odev`, removed `odev.py`
odev can now be run with the installed ~/.local/bin/odev symlink, that points to `__main__.py`, or by doing `python3 -m odev` from the repo root.

[ADD] utils: imported NDA shconnector script from `connect-plus` repo

[ADD] odoosh: ported over from `psbe-custom-upgrade` PR #17 as `sh`

[IMP] cli: print args before doing anything else, including __init__

[ADD] utils: added secret storage with agentcrypt (also, github API)

[REF] odoosh: split upgrade class into Base and -manual, small fixes

[ADD] odoosh: upgrade-merge method for upgrading with a PR merge

[FIX] sh upgrade-*: ensure copied upgrade paths are added for cleanup
(although in practice this was already taken care of at L150, it's better if `_prepare_upgrade_path_files()` does it too for some futureproofing)

[REF] sh upgrade-*: moved build code into own `wait_for_build` method

[FIX] sh upgrade-*: fixed rsync paths bug

[FIX] sh upgrade-merge: longer wait time for sh build to appear

[IMP] sh upgrade-merge: flashy warning to confirm before merging PR

[IMP] sh upgrade-*: small fixes, tweaks, TODOs

[ADD] sh upload: first implementation of SH database upload command

[REF] odoosh: renamed `project` argument to `repo`

[ADD] sh rebuild: first implementation of SH branch rebuild command

[IMP] cli: less verbose with parsed args

[IMP] odoosh: fancy progress bar while waiting SH build

[IMP] sh rebuild: flashy warning to confirm before staging rebuild

[FIX] __main__: relative imports when called from symlink

[IMP] odoosh: added show progress option to rsync upload

[FIX] quickstart: fixed url regex

[IMP] secrets: implemented secret deletion functionality

[IMP] shconnector: valid session tests, expired credentials renewal

[IMP] odoosh: handle missing build cases

[IMP] odoosh: better handling of SH build warnings

[ADD] sh upgrade-wait: command for generic SH builds (redeliver/push)
also upgrade code refactoring/DRY and bugfixes

[IMP] sh upgrade-wait: long 10min wait for build to appear

[FIX] sh upgrade-*: cleanup upgrade_path config before removing files

[ADD] *: added `noconfirm`/`-y` cli option to skip prompts (+TODOs)

[REF] Global framework refactor

- Automatic command loading
- Automatic arguments parsing
- Improved command registering and dispatching
- Added overall typings
- Improved exception handling in main process + added custom exceptions

Overall reorganization of the project structure and split accross directories
for clarity.  Commands will now extend predefined structures with helper methods
and class attributes.  Commands will be automatically loaded from the 'odev/commands'
directory and sub-directories without requiring any init file or export.  Added a directory
to store commonly used constants.

[IMP] Add configuration manager class

- Load and write config files from/to a standardized location using aliases
- Set and get values from configuration at anytime
- Automatically save current configuration to file with no explicitly accessing the os

[REF] Gloabl refactoring of utils

Misc improvements to utils and split of methods in different files,
regrouped by scope or features.

[REF] Logging and user interraction

Global refactor of the logging mechanism to extend standard logging capabilities.
Added theming support to the logger to allow for minimalistic (original odev style)
or extended (logging library) styling.  Interractivity is assured through the logger
instead of external utility methods thanks to the addition of custom 'logging levels'helpers.
Also reintroduced requirements.txt file.

[REF] Main process refactor

Add support for few custom exceptions.  Improve signal handling.
Use new logging mechanism.  Improve project structure.

[REF] Setup process refactoring

Improve project structure.  Make setup more robust, default to user-specific
directories.  Improve configuration handling.  Find previous configuration if re-running setup.
Prevent breaking user's system with incorrect path handling.
Do not ask for root access anymore and actually advise against it.

[REF] Original commands

Rework original commands to work with the new framework and make use of the new logging capabilities.
Reorganize the project directories to auto-load commands through the registry.

[IMP] Add automatic help command

Add support for 'odev help' to display hints about all or specific commands.
Automatically loading description, usage and arguments from commands loaded into
the registry.

[IMP] Add support for odoo-bin commands

Add support for various odoo-bin commands, including a refactor of 'odev run'.
Now providing specific commands and support for odoo-bin shell and cloc.  Also
providing a command wrapper for enabling tests when running a database.

[REF] Odoo SH commands

Refactor of Odoo Sh specific commands to work with the new framework,
logging and utils.

[ADD] Config commands

Add commands for easily setting or reading odev configuration.

[IMP] Auto-update

Automatically check for updates in the current odev branch and pull changes if necessary
(and approved by the user).  If updated, restart the process immediately to benefit from
the new update(s).

[FIX] SQL error handling and escaping

[IMP] Capture SIGINT and SIGNUM in subprocesses

[IMP] Capture SIGINT and SIGNUM in curl subprocess

[FIX] Write symlink to /usr/local/bin for system-wide access

[FIX] Update psycopg2 python dependencies

[FIX] Add decorator dependency to requirements.txt

[DOC] Refactor README.md

[FIX] Addons-path argument parsing in cloc command

[IMP] Print newline before cloc report

[FIX] Setup: Symlink creation and permissions management

[IMP] Doc and help

[FIX] Restart current process after code upgrade

[IMP] Force fetch before update check

[IMP/FIX] Allow dumping dev/staging databases from Odoo SH

+ fix regular expressions for finding tokens

[FIX] README: reorder installation steps

Do not try to install requirements before clone the repository as requirements.txt does not exists yet.

[IMP] Git error handling

Detect errors in git subprocesses (git fetch, git pull) and print a useful message.

[FIX] Sanitize URL when dumping databases

[IMP] Allow saving and reusing arguments in run commands

Applies to the following commands:
- odev run
- odev test
- odev shell
- odev cloc

[FIX] Traceback in list with new databases

[FIX] Allow to run cmd on self imported db (#43)

* [FIX] Allow to run cmd on self imported db

* [FIX] Fix review

[IMP] init: Create SQL unaccent extension on database creation

The 'unaccent' SQL extension is used on Odoo database to perform in-text search
while stripping accented characters (i.e. 'e' matches 'é'). Odoo SaaS and SH databases
have this extension enabled and available, but databases initialized locally with
'odoo-bin' do not activate it when installing the base module.

This commit provides this extension as defined in Odoo SaaS/SH SQL dumps on empty databases
initialized locally.

[IMP] `README.md`: track all `odev*` branches (#39)

[IMP] logging: set log-level at script's start

Set log-level before loading the registry if provided in command's arguments.
This enables support for custom and debug log-levels outside of the commands scope,
as otherwise the log-levels where set at the initialization of the registry.

[FIX] Remove unused imports

[DOC] REAMDE.md: improve contributing section

Add text paragraph to present issues and new feature requests.

[FIX] odoo sh command line args

The merged odev-abt* branch was using slightly different command line args.

[IMP] upgrade: add support for database upgrades (#49)

Closes #44

Upgrade a local Odoo database, running migration scripts between each major versions.

[FIX] upgrade: remove unused argument parsing

Argument `--silent` was used for debugging purposes but removed after
validation of the features. Though parsing of that argument was not
correctly removed.

Also moved the `upgrade` command to the `odoo_bin` directory.

[IMP] restore: add `--no-clean` argument (#53)

Closes #51

Allows running the `restore` command without cleaning the database, useful for upgrades.

[IMP] run: install `requirements.txt` for custom addons (#54)

Closes #52

Previously to this commit, only the requirements from the `odoo/odoo` repository
were installed. This automatically finds new `requirements.txt` files in the provided addons
and attemps to install them if necessary.

[ADD] Support`restore``sql.gz` dumps (SH backups)

[FIX] dump: using incorrect support url on saas instances

[FIX] clean: set expiration date as datetime for versions >= 15.0 (#56)

Closes #55

The database expiration date became a datetime object in version 15.0,
as opposed to a date object in previous versions.

[FIX] `quickstart`: pass `no_clean` argument to `restore`

[FIX] shconnector: infinite recursion bug on expired SH session

[REF] odoosh: re-rename attributes `*repository` to `*repo`

[IMP] odoosh: use branch history (trackings) to follow new build

[IMP] odoosh: more robust build following (use tracking id)

[IMP] sh upload/rebuild: adapt code for branch history tracking

[REF] config: refactored and improved ConfigManager, added autosave

[IMP] shconnector: odoo impersonation for login (instead of github)

- shconnector now requires repository + GH username for session setup
- refactored shconnector methods to remove repo argument
- implemented util.credentials to provide helpers for getting credentials
- removed secret_storage helper and supporting classes
- small OdooComCliMixin for providing odoo credentials cli options
- refactored and improvedConfigManager, added autosave

[FIX] sh upgrade: contextmanager import from wrong library

[ADD] sh upload: implement keep filestore feature

[IMP] Add section about `ssh-agent` to `README.md` (#29)

[ADD] odev sh upload: dump zipfile sanity check (#32)

* typo in typehint
* [ADD] odev sh upload: dump zipfile sanity check
* PR comments ABT

[FIX] commands: fix broken commands arguments inheritance

[FIX] sh upgrade: fix broken bash paths escaping using backticks

see https://unix.stackexchange.com/a/27432

[FIX] adjust files mode to 644

[FIX] config: fix MutableMapping import conflict w/ typing-abc (#80)

[IMP] Auto install pudb and ipdb to each venv (#68)

[FIX] Fix debug log level (#69)

[IMP] `restore`: pipe extract

The temp partitions size can be limited. The original solution to extract zipped dumps was using pythons `tempfile` lib which by standard writes to the temp partition. Especially big databases are able to fill the temp partition on many systems.

Why use the filesystem in the first place?
`dump.sql` is directly piped to `psql`. The filestore is handled according to the users choice, also w/o `tempfile`.

[FIX] Fix requirement install (odev run) (#82)

* [FIX] Fix requirement install (odev run)
* [FIX] Fix review
* [FIX] Fiw comment 2
* [FIX] remobe blank line

[IMP] Use worktree instead of cloning (#67)

* [IMP] Use worktree instead of cloning

* [FIX] Fix review comment

* [FIX] Fix comment review

* [FIX] Fix review , remove unused import

* [FIX] Fix review , .git is a DIR or a FILE

[FIX] Remove useless logger oopsy

[FIX] Fix requirement.txt by adding packaging (#83)

[FIX] Replace match statements (#84)

Ensure compatibility with python 3.8 because the `match` statement was only introduced in version 3.10.

[FIX] github: remote default fallback

Remote branch may not always have the name `origin`. Accessing that name fails for some repos (e.g. odoo enterprise).
Resolved by adding a method calling the 1st remote branch as fallback if there is no `origin`.

[IMP] Add no-root scenario to setup

[REF] github: refactor module, improve flexibility, add documentation

* moved "check if cloned and updated" code from `odoo` module and split into multiple functions
* refactored, DRYed and renamed `pre_run` fn from `utils.odoo` (now `prepare_odoobin`)
* adapted usages of `prepare_odoobin` for the changed signature
* added head == branch sanity check to `git_pull`
* DRYed `self_update` function by improving and calling `git_pull`
* small refactorings here and there
* added docstrings and type annotations
* Black formatted
* merged with `use worktree instead of cloning (#67)`
* merged with #63

[IMP] odoo: improved version handling and parsing

- improved odoo-to-python versions mapping
- added `saas~` versions support
- added function to get a comparable `StrictVersion` object
- added function to get odoo branch name from version
- DRYed versioned repos folder path generation
- renamed `LocalDatabaseCommand.db_version` to more appropriate `db_base_version`
- added `LocalDatabaseCommand.db_version_parsed` to get a comparable `StrictVersion` for a db
- removed `RE_VERSION` constant as not used anymore
- added custom `InvalidVersion` exception
- refactored other version handling code with new utils functions

[IMP] exceptions: added base classes for all custom exceptions

- added modules docstrings.
- removed unnecessary `pass` after classes docstring.
- Black-formatted code.
- moved exceptions defined in `utils/github` to `exceptions/git`
- merges with #67

[IMP] upgrade: rewrite feature leveraging upgrade-platform code

- merged with #68
- merged with #82
- merged with #67

[IMP] *: use `Version` from `packaging` instead of `StrictVersion`

[FIX] sh upgrade: fix broken SQL backticks vs single quotes (#88)

[ADD] odev: offline support (#72)

This commit adds support for running `odev` in an environment that is not connected to the interwebs.
An error is still indicating that the connection to the remote git repo was not possible.

[FIX] comparing version with str during db cleaning (#89)

[IMP] commands: fix arguments merging across classes hierarchy (#87)

- also improve check for already-defined commands when the class is the same (due to implicit + explicit module imports)

[IMP] Implemant a new odev clone command (#92)

* [IMP] Split shConnector into two method login / impersonate

* [IMP] Make ask() more smart by checking if answer is in the list

* [ADD] Add method to check if an Odoo db is on saas

* [ADD] Add clone command to odev

* [IMP] Invoke odev clone at the end of quickstart cmd

* [FIX] Fix after review

[IMP] Automatically install new requirements during self update (#85)

* [IMP] Automatically install new requirements during self update
* [REF] python: refactor install requirements/packages to new util

Co-authored-by: abk16 <[email protected]>

[FIX] Add missing requirement after rebase (#95)

[IMP] Use CredentialsHelper in dump cmd (#96)

[FIX] Fix pg_restore that failed with wrong args (#97)

[FIX] Fix clone call from QS (#99)

* [FIX] Fix clone call from QS

* [FIX] Fix after review

[FIX] Fix do_raise method after review + odev clone (#101)

[IMP] Print confirm message even if -y/-n (#100)

[FIX] test: correct arguments order with inherited `args` (#106)

[FIX] clone: dev path in config is without 's' (#109)

Issue: TypeError: expected str, bytes or os.PathLike object, not NoneType

[IMP] run,cloc: running command as info, not debug (#103)

[WIP] Add pull command and ask on run after x days (#110)

* [WIP] Add pull command and ask on run after x days

* [IMP] Add clone command to the readme

* [FIX] Fix after review

* [FIX] Fix review

[IMP] Add color bar in the log (#94)

* [WIP] Add color bar in the log

* [IMP] Put config inside theme

[FIX] Fix empty answer on confirm triggering Index out of range (#113)

[WIP] Fix pull command (#114)

* [WIP] Fix pull command

* [FIX] Fix after review

[IMP] Use a globals_context var to share data between successive calls to run_with()  (#102)

* [IMP] Allow to passe a dict to a command to get back some data

* [FIX] Fix review

* [FIX] Fix review 2

[FIX] Fix worktree list creation and kwargs (#117)

* [FIX] Fix worktree list creation and kwargs

* [FIX] Fix after review

[IMP] git_pull: fetch once per run per repo, and merge vs pull (#111)

[FIX] git_pull: fetch-once feature merge fix with #110 (#122)

[IMP] Allow to pass --without-demo to init and qs (#120)

[FIX] Remove command name printed twice in help (#119)

[IMP] Add -t --template argument to run/remove and qs (#112)

* [IMP] Add -t --template argument to run/remove and qs

* [FIX] Fix after review

[ADD] Add Odev scaffold and pleasedo method (#93)

* [ADD] Add scaffold method

* [IMP] Improve separation between class, qs project

* [FIX] Re-apply commit from ACR and fix some bug

* [IMP] Use new ask method, change help text

* [IMP] Fix template, fix texte, update staging db name

* [ADD] Add pleasedo command

* [FIX] Only show Assume Yes/No once

* [WIP] Fix string

* [FIX] Remove the second call to clone (already present in quickstart

* [IMP] Get path from clone command to scaffold directly in the repo

* [WIP] Fix git clone cmd

* [WIP] Fix path from clone

* [FIX] Fix error on backend view if field is empty

* [FIX] Fix after review

* [FIX] Remove import test from init file

* [FIX] Fix staging url

* [IMP] Auto install pre-commit if git_repo

* [IMP] use path from clone if exist

* [FIX] Fix review second pass

* [FIX] Remove useless comment and rename task_id

* [IMP] Add unit test file if needed, split method

* [IMP] Handle asset for v15

* [IMP] Handle depends on business flow

* [IMP] Fix calling super() for method and compute code

* [IMP] Add support for mail and activity mixin

* [FIX] Fix init for tests folder

* [FIX] Fix constraint not scaffolded

* [FIX] Fix requirements.txt config

* [FIX] Fix xml_id for saas and add index field param

* [FIX] Fix constraint string

* [IMP] Fix string, remove todo

* [FIX] Fix template error and string

* [FIX] Move default space value for data into the template

* [FIX] Fix detection of saas database

* [IMP] Continue pleasedo even if dump failed

* [IMP] Retun Sh repo if prefect match

* [FIX] Fix fix fix after review

[FIX] Fix wrong depends for Unicode + improve requirement based on ABT proposal (#123)

[FIX] Fix get_worktree_list (#124)

[IMP] Only check for odev update once a day (#125)

* [IMP] Only check for odev update once a day

* [EOF] Fix

* [FIX] Fix after review

[IMP] Only try to install requirement if install or update

[ADD] VSCode debug config generator (#121)

Create a vscode config file to debug odoo projects

[ADD] Add the exporter to odev (#127)

* [ADD] Add the exporter to odev

* [FIX] Fix class name for color logging

* [FIX] Fix broken init_config in scaffold

* [FIX] Remove usless import

* [FIX] Remove wrongly added newline

* [FIX] Fix after review

[ADD] unix-style help for all commands (`odev cmd --help`) (#128)

Improve backup dump + `requests` > `curl` (#126)

* [IMP] dump: refactor connection flow and error handling

Replace usage of `curl` subprocess calls with python `requests` package.
Improve HTTP requests status check using HTTP response codes instead of parsing text headers.
Improve error handling on large databases and provide sensible messages to the user.

* [FIX] commands: add `do_raise` arg if not used through `run_with`

The Quickstart command uses `do_raise` when called by PleaseDo, but that argument was not set when running
Quickstart manually, resulting in a traceback during controlled error handling.

* [IMP] dump: fallback to daily backup

When the backup to download is too large to be fetched through the support page of SH projects,
fallback to downloading the last daily backup through SCP.

[FIX] help: executable path in global help message (#129)

[IMP] deploy: add support for `odoo-bin deploy` (#48)

* [IMP] deploy: add support for `odoo-bin deploy`

Deploy a local module to a SaaS database, or a local database if no URL is provided.

[FIX] Add custom repo for dubai,hong kong and usa

[ADD] pre-commit: configuration & adaptations (#132)

* [ADD] pre-commit: configuration & adaptations

* [REM] pre-commit: project.toml config for black

* [IMP] pre-commit: config for black

* [IMP] pre-commit: MyPy configuration and initial corrections

* [FIX] odev: make it green again

Fix all remaining linting errors in VSCode.
... at least on my machine.

* [REF] odev: `_logger` code coherence

Switch from `logger` to `_logger` variable name accross the whole codebase.

* [IMP] pre-commit: isort lines after import

* [IMP] pre-commit: autoflake remove unused variables

* [FIX] shconnector: regular expression format

* [DOC] readme: update worktree vs single-branch

* [DOC] readme: update required python version to 3.8+

* [REF] odev: code coherence `%s`->`f-string`

* [FIX] pleasedo: support for psql templates

* [FIX] pleasedo: quickstart `do_raise`

* [FIX] scaffold: variable naming  `data`->`views`

* [FIX] commands: conflicting arguments

* [VER] 2.1.0

* [REF] scaffold: cast `self.version` to `Version` instead of `str`

* [FIX] util.py: restore previous version & ignore pre-commit

[IMP] Standardize database creation and check (#138)

[FIX] Remove default .Sh value for export type (#136)

[IMP] Remove pleasedo and use quickstart instead (#137)

* [IMP] Remove pleasedo and use quickstart instead

* [FIX] Fix after code review

[FIX] Quickfix missing inherinting for qs (#139)

[FIX] python install command

[FIX] pull command

[IMP] Clean Saas module, install req on first run, avoid sudo (#144)

* [FIX] Fix cleaning by removeing saas_module

* [FIX] Install requirements.txt on first run

* [FIX] Prevent to run setup or odev as root user

* [FIX] Dump version number for bugfixes

* [FIX] Fix dependency problem with Jinja by warning the user

* [FIX] Fix after review

* [FIX] Fix help

[IMP] Create a sandbox venv linked to the database (#140)

* [WIP] Create a sandbox venv linked to the database

* [FIX] Fix after review

* [FIX] Reuse venv if already existing, improve logger, bug folder doesn't exist

* [FIX] Rename alternative venv argument

[IMP] Try to generate a repo path if clone failed (#147)

[IMP] Allow odev dump to dump a locate database (#149)

* [IMP] Allow odev dump to dump a locate database

* [FIX] Fix after review

[IMP] Allow user to add queries to the clean command #blackmode (#148)

* [IMP] Allow user to add queris to the clean command #blackmode

* [FIX] Fix after review

* [FIX] Fix after review

[FIX] Fix DBExistsCommandMixin help text (#150)

[FIX] Fix pre-commit install when scaffolding (#146)

* [FIX] Fix pre-commit install when scaffolding

* [FIX] Fix following review

[FIX] Surround template name with quote (#145)

[FIX] unknow log level when '-v' in sys.argv (i.e. --database psbe-vsomething) (#153)

[FIX] fix saas dump error

[FIX] fix SH dump error (#156)

When running `odev dump` for an online db, `AttributeError: 'DumpCommand' object has no attribute 'url'`

[FIX] Fix branch_name when scaffold without clone (#158)

[FIX] Fix regression when using dump with qs (#157)

[FIX] Fix get_odoo_version for saas (#159)

[FIX] Disable 2FA on admin account and 50 firsts local accounts (#160)

[FIX] sh: increase poll interval, default retry sh connections (#161)

[FIX] Disable 2FA on admin account and 50 firsts local accounts (#163)

* [FIX] Fix totp_secret query , execute only if exist

* [FIX] Fix totp_secret query , execute only if exist

* [FIX] Fix log info for the first 50 users

Odev precommit sh monitoring (#133)

* [ADD] sh-monitor: monitor test on SH databases

[IMP] monitor: parse a csv files with odoo sh projects and run tests

* [FIX] github: `get_worktree_list` installed versions was always empty

* [IMP] monitor: checkout production branch

* [IMP] monitor: tests runtime

* [IMP] monitor: save info to ps-tools database

* [IMP] monitor: cloc + pre-commit + credentials + logs + handle single url

* [IMP] utils: improve pip packages install + handle pip errors

* [IMP] logging: sh_monitor command tree color

* [FIX] create: create database with lc_collate and encoding

* [IMP] monitor: results fallback + build errors + prepare venv

* [IMP] monitor: build results + fetch submodules + pre-commit config update + repositories cloning

* [IMP] monitor: include submodules

* [REM] pleasedo: delete file (reset correct state)

* [FIX] exporter: C416 Unnecessary list comprehension

* [IMP] monitor: create project before tests + ps-tools database in config

* [FIX] @sea-odoo review comments

* [FIX] monitor: no pre-commit config found for version

* [IMP] monitor: filter assigned/unassigned projects

[FIX] upgrade: fix stdin in subprocess to enable debuggers (#164)

[FIX] Fix field_name changed on ps-tools (#165)

[FIX] Fix url-detection in scaffold command (#166)

* [FIX] Fix url-detection in scaffold command

* [FIX] use None instead of empty string

[ADD] cloc: output csv formatted data (#169)

[FIX] pin MarkupSafe==2.0.0 for copier/jinja incompatibility (#167)

[IMP] github: patch GitPython for bug using relative worktrees (#168)

[FIX] Fix call to clone only if we have a repo (#170)

[FIX] odev: allow inserting blank between imports

The error

> Cannot parse: 3:27: from . import modelsimport logging

The solution: remove the - to allow blanks

[IMP] odev: set https website, as it should be

Set url to https, as in pre-commit conf https://github.com/odoo-ps/psbe-ps-tech-tools/blob/14.0-pre-commit-config/.pre-commit-config.yaml#L42

[REF] commands: move odev runtime-specific code to `Command`

[ADD] basecommand_test: new `~._get_merged_arguments()` method tests

[FIX] code: fix `render_debug_template` signature and `upgrade-path`s

- remove `database` arg from `render_debug_template()`
- fix `upgrade` repo paths, non-included `migrations` folder due to wrong kwargs in render fnc.

[ADD] code_test: new `odev code` command tests

- also test for `upgrade` repo paths

[ADD] .github: PR checks workflow

- only run actions on pull requests targeting `odev`
- 2 jobs:
  - pre-commit: run pre-commit and check that it was correctly applied on code
  - tests: run tests suite with pytest and check coverage (nonblocking)

Co-authored-by: Marten (msc) <[email protected]>
Co-authored-by: abk16 <[email protected]>

[REF] shconnector: remove duplicate `get_project_info` method

[REF] commands: rename `OdooSHDatabaseCommand` `repo` to `project`

- also `OdooUpgradeRepoMixin`: added `--custom-util-repo-path` as args alias for existing `--psbe-upgrade-repo-path`, the latter preserved for backwards compatibility (but `custom_util` was removed from that repo)
- small TODOs

[ADD] submodule: new command to add a submodule on odoo.sh

[ADD] prepare-util: new command to prepare util(s) for odoo.sh

[FIX] upgrades/3.2.0: do proper `girurlparse` packages cleanup

[FIX] rename `psbe_upgrade_repo_path` to `custom_util_repo_path` #183

[IMP] allow to run same db in web server and shell

[IMP] avoid force validating upgrade paths

Currently when running odev code [dbname] [path] will generate error when trying to validate the upgrade paths .

[IMP] create: also copy template filestore (#182)

- added optional cli switch `--no-filestore` to disable this behavior

[IMP] remove: add new option `--keep-filestore` (#182)

- also refactored `keep_template` attribute to an actual cli argument

[IMP] commands: add arguments default in `run_with()`

Add defaults for missing arguments when calling a command with `run_with`.
The priority of the arguments is the same as `ArgumentParser`, specifically (from most important):
- `do_raise`, `capture_output`
- passed `kwargs`
- parser actions defaults
- parser arguments defaults

Also removed useless `*args`, since it would have never been used (Namespace accepts only kwargs).

[IMP] submodule: add `--update` switch to pull submodule (#191)

- adapted `prepare-util` to properly work with the new feature
- also refactored `_git_commit_context` contextmanager method to `GitCommitContext` class in `github.py`
- misc small methods refactorings and changes

[FIX] Fix lastrun key to avoid unnecessary pip req check

[FIX] clean: clean totp_secret on res_users (set to NULL instead of 'false') (#197)

[ADD] `export`: support local exports

Local use of `export` was not possible due to:
- hardcoded standard port (443)
- hardcoded jsonrpc via SSL

Port is now detected in url cmdline parmeter. A basic detection of local urls deactivates SSL.

[FIX] Fix read_safe method after migration to odev (#194)

* [FIX] Fix read_safe method after migration to odev

* [FIX] Fix after review

[FIX] github: fix worktree list regex (#200)

[^] will match any character that is not in the set
while we want to match the whole string master.

This is causing issue for saas worktrees as the letter "s" and "a" are
in "master" and in "saas"

This causes the run command on a saas-15.X database to pull everytime
you run a database which is slow

[IMP] clean: add a localhost outgoing mail server

[IMP] clean: add versionised clean_queries

[FIX] Secure path deletion and improve version detection (#181)

* [FIX] Secure path deletion and improve version detection

* [FIX] Fix after review

* [FIX] Fix after review

[ADD] allow no extract of dump.sql from sql.gz (#162)

It is not necessary to extract dump.sql from gzip file in all situations.
Current default is to extract so preserve this behaviour unless
`-x,--no-extract` is provided. (Similar to RD `upgrade` script).

[FIX] create,rename: update databases config (#176)

`odev create new_db template_db` does not add the
`new_db` to the databases config, even if the
`template_db` is in the config.
`odev rename ...` does not save the changes to the
databases config.

[IMP] utils.odoo: improve version parsing, conversions, edge cases

- properly handle all known saas version schemes, including pre-v11 ones
- fix pre-v11 saas branch names from version
- normalize any version with minor != 0 to saas versions (except 6.1)

[ADD] odoo_test: new `utils.odoo` version handling functions tests

- also refactored tests directory structure

[IMP] enable running databases with odoo version <= 9.2

- use lessc v3 for ver < 10.0 databases
- add version-specific node_modules to PATH

Co-authored-by: Maurin3 <[email protected]>
Co-authored-by: abk16 <[email protected]>

[REF] refactor "run odoo-bin" code to `utils.odoo.run_odoo` function

- small common run/init/cloc commands code refactor into `OdooBinMixin`
- added db-specific venv removal in `remove` command + argument to optionally skip it (+ small refactor)
- pull up args saving code from `RunCommand` to `OdooBinMixin`, refactored to separate methods
- split saved arguments from addons in config (they wouldn't appear like that in odoo cli anyways)
  - this check keeps the existing code but saves to the `addons` key, so no upgrade script is necessary
- small misc code simplification
- rename `--env` CLI arg for separate db venv to `--venv` (and remove `-e`)

[IMP] odev: remove a db already drop with dropdb

If we create/run a database with the `odev run` command, the following 3
parts are created:
    - A database in SQL
    - A filestore
    - An entry in .config/odev/database.cfg

 If the user use the command `dropdb`, only the database in SQL will be
 dropped. We find ourselves in a hybrid state, where it is no longer
 possible to create a db with the same name or to use the `odev remove`
 command to delete it properly.

 With this dev, a user can use odev remove to delete the filestore +
 the config entry even if the SQL database no longer exists

[IMP] disable TOTP policy on neutering (#201)

[ADD] bash completion script (#172)

See `./complete_odev.sh` for usage.

[ADD] odev code: templates for empty db / mailcatcher (#212)

* [ADD] code: configuration for empty database, `tasks.json`; adapt/extend tests (WIP)

* [ADD] tests for filestructure and `tasks.json` assertion

* add template args for mailcatcher; debug command path validator

* adapt order of depends in template for (python) json decoding

* fixup! adapt order of depends in template for (python) json decoding

* boolean logic is hard

* make tests pass for empty `upgrade_repo_path`

* mock `ConfigManager` for environment-independent test results

* [ADD] odev code: mailcatcher preLaunch task to db launch configs

* [ADD] odev code: exclude `util_package` from custom module list

[FIX] pre-commit: bump pre-commit-hooks-safety to 1.3.0 for bugfix

[IMP] restore: progress bar for dump file import

- use enlighten to display a progress bar of the dump file restoring process
- use python to open the file to pass as stdin to the restore subprocess command
- for zipfiles, use `ZipFile.open` to stream uncompressed data directly to subprocess pipe
- renamed `pg_subprocess` to `restore_subprocess`, refactored signature, renamed decorated functions

[ADD] restore_test: new tests

add tests

monkey patch call to psycopg

more monkey patching of psycopg

[FIX][Scaffold] Fix ondelete args name (#202)

[IMP] sh_monitor: add multi company support

[IMP] Check requirements.txt timestamp to avoid useless call (#217)

* wq[IMP] Check requirements.txt timestamp to avoid useless call

* [FIX] Fix after review + add mig script

* [REF] refactor "lastrun" code to OdooBinMixin

* fixup! [FIX] Fix after review + add mig script

* [REF] rename `lastrun` to `last_run` + adapt mig script

Co-authored-by: abk16 <[email protected]>

[FIX] Fix error when models is missing (#219)

[FIX] run: venv name is not set correctly

[REF] Use api key to download saas db

Refactore the download of SAAS dumps to use api key since 2FA
Remove the deletion of tmp dumps after quickstart and allow to reuse
dumps downloaded the same day
Use stream to download dumps and log progress with enlighten

[FIX] restore: restoring pg_dump formated sql

Both psql and pg_dump can generate a .sql file but the format is not
the same.
It needs to be restored with the right tool.

[FIX] scaffold: fix saas version issue

[IMP] scaffold: add a config to not use pre-commit

[REF] utils, dump, deploy: sanitize url

Fix the is_saas_db method to work with urls without https
Move the duplicated code of url sanitization in utils

[IMP] utils: update python version list

[IMP] Bump python version to 3.8 for Odoo 14.0 (#232)

* [IMP] Bump python version to 3.8 for Odoo 14.0

* [FIX] test_get_python_version: align data with expected behaviour

[IMP]init: initialize db from Odoo repository

[ADD] run_standard: add a new command to run database as standard (#227)

The command is just a scaffold to clone R&D repo and run the
clean_database command
https://github.com/odoo/support-tools#clean_database

[FIX] clean: MailHog server for Odoo 14 (#235)

As SMTP Authentication was backported to Odoo version 14.0, the cleaning queries
had to be adapted. The `smtp_authentication` was only filled in for versions
greater than 15.0 but now includes versions from 14.0 upward.

Additionally, refactoring the query's contruction to avoid duplicate code.

[ADD] Add timesheet command (#90)

[FIX] clean: Reset Mailhog queries for Odoo 14

SMTP Authentication wasn't backported to Odoo version 14.0 so 4b8a5d6d5555c37f1e1959b1cbd84c17f6b778e4
introduced an issue. This commit fixes it.

[ADD] restore/clean: set website domains to NULL  (#243)

* [ADD] restore/clean: set website domains to NULL

to make testing multi website locally possible

* SEA: fix query for dbs with website module not installed

Co-authored-by: sea-odoo <[email protected]>

* ABT: add log info informing user about websites/domains

Co-authored-by: sea-odoo <[email protected]>

[FIX] upgrade: support odoo version 16.0 target, venvs fixes (#248)

[IMP] clean: find most sane admin user record for creds reset (#249)

[IMP] shconnector: make bad credentials error more readable (#254)

[IMP] utils.github: properly parse git worktrees list info

[FIX] utils.github: resolve worktrees paths to check identity

The current logic in `git_worktree_create()` for ensuring a worktree path is checked out works by: attempting to add the worktree, and if that fails, assuming that if it appears in `git worktree list` it means it exists already. When comparing paths, we need to make sure all symlinks are resolved first, both in the worktree path we're trying to create and the paths returned by git.

[FIX] fix flake8 url in pre-commit config

[FIX] .github: enforce python3.8 version

[IMP] run: allow force-version argument to force an upgrade

Makes testing upgrades much easier with odev.

[IMP] upgrade: deprecate command (#263)

- suggest test.upgrade.odoo.com server instead
- see discussion at https://discord.com/channels/678381219515465750/1034431597308555355/1039479207740313670

[IMP] psql: access the cursor with `.cr` instead of `.cursor`

It's more cozy (coming from Odoo where we access it with `env.cr` or
just `cr` in upgrade scripts).

[IMP] remove: allow removing non Odoo databases

When creating a database with the create command, the user might want
to remove it without initializing it. Currently that fails, raising an
Exception when getting the version with
`version = self.db_version_clean()`.

This commit fixes that and adds a warning message to the prompt when
deleting a non Odoo database.

[BUMP] Odev version

[FIX] Fix branch name after odev migration to his own repo (#13)

[FIX] Fix template restore command that failed if db removed from config (#7)

[FIX] Fix cleaning query for fetchmail_server (#10)

[FIX] Fix submodule slowness detection (#8)

* [FIX] Fix submodule slowness detection

* [FIX] Fix after review

[FIX] Fix dump command for local database (#9)

* [FIX] Fix filestore folder name

* [FIX] Fix dump command for local database
- Database arg should not be present with database_required=False
- Create folder if doesn't exist yet

Odev fix scaffold sea (#12)

* [FIX] Fix make column1 and column2 string args

* [FIX] Put fields and models in lowercase

* [FIX] Fix empty model name if named 'x_'

* [FIX] Don't add mail.* inherit if base model

* [FIX] Fix selection field string for integration (edi)

* [FIX] Fix missing compute if no description

* [FIX] Allow per version folder, add bootstrap5 for Odoo > 16

* [FIX] Fix trailing whitespace before depends

* [FIX] Fix ir_act_window_view template

* [FIX] Remove CDATA for type=hml xml node

* [FIX] Fix ir_action_windows_view template and domain

* [FIX] Fix model_name in ir.ui.view template

* [FIX] Fix ir_model_access model name when exported

* [FIX] Translate field into module field in the context

* [FIX] Fix base_automation export that doesn't generate anything

* [FIX][Scaffold] Fix view name to follow standard

* [ADD] Add autoflake to remove unused import

* [FIX] improve ir_actions_act_window.jinja template

* [FIX] exporter: do not export ir.filters by default

Co-authored-by: nda-odoo <[email protected]>

[FIX] Last run not working with venv (#15)

First issue is that by default if the last_run is not in the config it
is set to now.
This causes an issue with venv where it compares the date of edition of
the file with the last run in order to trigger or not the installation
of the requiremements.
If by default it is now then it will never trigger the installation.

The second issue is that the last_run is not updated when the command
run is executed as you have to ctrl-c to stop the execution of Odoo it
kills odev before it has time to update the last_run.
I added an upgrade script to reset all last_run date as to ensure all
venv are up to date.

Third issue is that when comparin the last_run date with the last
edition date of the requirement files it requires that all files have
last edition date greater than the last_run.
This is ok for the first run but most likely after that only one
requirement file will be updated at a time and odev will never pickup
those changes.

[FIX] Scaffold missing database argument (#18)

[FIX] Scaffold path missing database

database arg does not exist, so in case of none url_info it can scaffold
to args path

[FIX] quickstart: restore dump downloaded online (#17)

This PR introduced the issue: https://github.com/odoo-ps/ps-tech-odev/pull/9

The name of the dump was previously the name of the database.
Since that fix it is the name of the database in the url.

[IMP] python.py: log errors if pip install fails and exit

[FIX] python.py: ignore special case for util package in requirements

`util_package` is added to odoo.sh projects as a submodule with the
help of `requirements.txt`, where a line is added that points to a
filepath specific for odoo.sh containers. This makes the `pip install`
command return a non-zero exit code because of the none existant path
on the local machine.

Add a special case to check for this until this process changes.

[IMP] Enable GitHub workflows and add coverage report

[FIX] commands.dump: Namespace has no 'database' parameter (#23)

* [FIX] LocalDatabaseCommand: database not required if argument no added

Makes sure the `database_required` attribute is set to `False` if the
`add_database_argument` attribute is falsy.

Introduced by #9
Fixes #22

[FIX] Traceback when user refuses download of daily ackup

[IMP] pre-commit config: Set `xmlWhitespaceSensitivity` to "strict"

Lines in XML files that exceed 120 characters are formatted by pre-commit
by breaking the lines with newline characters where possible.

This is generally safe because HTML ignores these newline characters, but
it's not safe for inline elements, having the following (known) side effects:

- `mail.template`s are broken if the subject for ex. contains a
line-break

- translation issues depending on the version of Odoo used

This can be fixed though by using `xmlWhitespaceSensitivity: "strict"`
in the prettier config, see
https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting.

[IMP] make odev compatible with ubuntu 22.04 (#27)

2 issues so far with odev and ubuntu 22.04:

python 3.6 is not available through deadsnakes ppa anymore, see
https://launchpad.net/~deadsnakes/+archive/ubuntu/ppa
Solution: use python 3.7 instead

python3.X-distutils is not installed by default anymore

handle setuptools 58 not being compatible with python version lower than
3.8

[IMP] pre-commit config: use the standard .flake8 config

odev pre-commit was ignoring unused imports because of the flake8 config,
which is fixed now to use the standard version we have, plus set flake8
to ignore F403 in `__init__` files only.

[IMP] *: remove unused imports

[IMP] odoo.py: more robust url parsing

Currently 'get_database_name_from_url' fails if the url is for
ex `https://test.odoo.com/` because of the trailing slash.

Fixed by using urllib which allows to refactor `sanitize_url` too.

[FIX] Fix wrong type rendering (Xml in py files)

[FIX] Don't print warning if there is no integration line

[ODEV][ADD] shortest_path: shortest path between two models (#16)

* [SHELL][TOOL] shell command: --script args + ShortestPathCommand

* [SHELL][TOOL] shortest_path: check if model defined in DB

---------

Co-authored-by: Rodesc <[email protected]>

[IMP] dump: add exception if no access to the dump route (#35)

For both SH and SAAS add a clear message about why the dump is not
downloading

[IMP] Add error message when virtualenv is missing (#37)

[IMP] Dispaly proper message when virtualenv creation fails

[IMP] restore: add bzip support (#36)

[ADD] Ask to Auto clean db older than 10 days (#11)

* [ADD] Ask to Auto clean db older than 10 days

* [FIX] Add option to whitelist from cleaning

* [IMP] Only ask once every 5 days

* [REVIEW] Change default value logic

* [TYPO]

---------

Co-authored-by: ros-odoo <[email protected]>

[IMP] odoo.py: handle missing scheme during urlparse

Use `tldextract` package to parse a URL instead of urlparse, which fixes
any issue when the scheme is not present in the URL or it's a
multi-level subdomain.

[ADD] pre_commit.py: add pre-commit command

This command can be used to install/update the pre-commit configuration
to the target version, supplied as an existing Odoo database name or a
valid Odoo version. It uses the git repo in the current working directory
and automatically creates a commit for the downloaded configuration.

Other details:
- refactored the fetching of pre-commit configs
- not using `GitCommitContext` for better control of exceptions

[IMP] odoo.py: fix sanitize url and refactor tldextract

Fix `sanitize_url` to work for multi-level subdomains too.

[FIX] Fix wrong ir.actions.act_window template (#45)

[FIX] .pre-commit-config: bump isort to fix broken dependency

Bumping isort to 5.12.0 to fix pre-commit failing to setup env due to dependency incompatibility.
See https://github.com/PyCQA/isort/issues/2083

[IMP] quickstart: allow to qs a database with `--no-clean`

[IMP] clean: make sure `database.is_neutralized` is set in db

- make sure when cleaning a database that in `ir.config.parameter` the parameter with key `database.is_neutralized` is set to `true` (this is used in standard v16 and support team neutralize script). This is in general a stronger indicator that a database was cleaned, vs. other more heuristic checks.
- add a `db_is_neutralized` helper method in `LocalDatabaseCommand` to (semi-heuristically) determine if a database was cleaned or not.
- bump version to 3.3.3 + add an upgrade script to make sure all dbs that (seem) cleaned have the `database.is_neutralized` set.
- fix an issue with `PSQL.query()` that would return always `True` on multiline statements starting with a newline (i.e. strip + dedent as a pre-pass).

[IMP] run: add ominous warning + delay when running unclean db

[IMP] disallow whitelist option in `_clean_old_db` for unclean dbs

[IMP] list: display warning for unclean dbs after the name

[FIX] upgrades/3.3.3: ignore errors on non-existing databases (#48)

[IMP] Add version increment instructions

[ADD] GitHub templates

- Multiple templates for issues (bugs and improvements)
- Template for pull requests

[REM] Pull request template directory: only keep one default

[ADD] Generic issue template

As issue forms are not supported on private repos, fallback to a generic
markdown issue template.

[DOC] Add contribution guidelines and simplify the README

- Renamed `doc/` to `docs/`
- Added `CONTRIBUTING.md` file
- Simplified `README.md` file and removed long sections

[DOC] Update links to Odev repository

Links pointing to the GitHub repository `odoo-ps/odev` have been updated
to point to the new repository `odoo-ps/ps-tech-odev`.

Also, a quick run of pre-commit was done to fix some formatting issues.

[ADD] Setup helper methods (recallable)

[IMP] Utilities and refactor of logging

[ADD] Temp test entry-point

[BUMP] Version: 4.0.0

[REF] main & setup

[REF] Refactor self-update

Refactor the self-update mechanism to improve reliability
and performance while keeping the code readable.

The new mechanism is based on the following principles:

1.  When odev is run, check its local repository for changes against
    the remote tracked branch (not targeting a specific branch anymore),
    but only if the check interval has passed since the last check.
2.  Add the possibility for the user to choose whether to download
    updates automatically, never download updates or ask before
    downloading.
3.  If an update is available and changes are pulled, check whether
    the requirements.txt file inside of the repo was modified. If so,
    install the new dependencies.

In order to save execution time, changes are not fetched in the current
process anymore but in a separate - detached - subprocess. This implies
that updates can be delayed until the next time odev is run but it has
the benefit of not slowing down the current execution.

[REF] Refactor update and upgrade mechanisms

Include update and upgrade of odev in a single framework class.

[IMP] Silence logging for external libraries in debug mode

[REF] Refactor commands loading and dispatching

Replace the registry with the more generic odev framework.

Move all existing commands to an `old` directory and create a
new `utilities` directory for the new help command (simplified
for testing).

[REM] Remove manual test files

Odev can now be tested manually using the system's `odev` command.

[IMP] setup.directories: consistent ask order for paths

Retry asking for the same path until a valid value is inputted
instead of asking all paths and validating them at the end.

[IMP] setup.update: Default to values already in config file

Use values from the config file as default instead of hardcoded values.

[REF] Various changes and improvements

- [IMP] Styling for `prompt` and `logging` with shared colors
- [REF] Replace occurrences of `str(Path)` with `Path.as_posix()`
- [IMP] Add support for various prompt types (text, checkboxes, etc.)
- [FIX] pre-commit flagged errors

[IMP] common.prompt: Remove unused __all__ attribute

[FIX] pre-commit flagged errors

[REF] Restore old_commands to commands

[REM] constant.arguments: help argument aliases

Moved to commands.utilities.help

[REF] commands.help

[IMP] common.odev: include assignation of framework in preparation

[IMP] common.commands.base: catch errors when parsing arguments

[IMP] commands.utilities.help: refactor string manipulation

Add new methods under common.string to manage indents and
dedents without requiring to import textwrap at all occasions.

[ADD] commands.utilities.setup: re-run odev's setup after install

[IMP] Add handling of command runtime errors

Add a new CommandError class that is caught when a command is run. This
allows to handle errors in a more generic way, and to display
an error log instead of a stack trace.

Add a new method `error()` to the BaseCommand class to generate
a CommandError without having the need to import the class.

[MOV] Ignore commands that still need to be refactored

[IMP] common.commands.base: page long text when printing to terminal

When trying to print a long text to the terminal, use a pager
(usually `less` on unix systems) if the text is bigger than the space
available in the terminal.

[REF] Export HelpCommand.__min_indent() to common.string

[FIX] Handle log level correctly in arguments

Remove the log level from command arguments after setting the global
level across the application.

[REF] Remove commented code

[FIX] Reset log level when restarting odev

[REF] Rename BaseCommand to Command

[ADD] Unit tests for odev.comm and odev.commands

[REF] common.commands.base: Refactor _is_abstract attribute

Replace the `Command._is_abstract` attribute with a class method.

[ADD] Connectors and connector mixins

Add a PostgreSQL connector to interact with PSQL and add a mixin
to apply this connector to commands instances.

[REF] Command class import

Make it less verbose.

[ADD] .coveragerc

Exclusion rules for coverage.

[IMP] Dynamic actions mapping for arguments parsing

Remove OptionalStringAction and a new RegexAction, as well as generating
a name for each custom action and mapping it to the action class.

This allows to use actions the same way as argparse standard actions,
and removes the need from importing the custom actions.

[FIX] ignore F405 to generated connectors.pyi definitions

[IMP] common.connectors: add SQL query execution to Postgres connector

Add a decorator to the connectors mixins to ensure that the connector
is connected before executing queries and/or requests.

[ADD] Odoo-specific version parsing

[ADD] common.databases: classes for handling local databases

Providing a name during instancing will open a connector to a local
running service of PostgreSQL.

[IMP] common.commands: print tables to the console

Add a method to the base Command class to print tables from a list
of column titles and rows.

[ADD] common.commands: Database command with additional database arg

[ADD] commands.local.list: simple version of the list command

[IMP] Improve existing tests for python and setup commands

[ADD] Unit tests fixtures and new tests

[IMP] commands.local.list: Add information and filter non-odoo databases

[MOV] command.utilities.list -> commands.local.list

[IMP] Repr for commands and databases

[IMP] main: measure process execution time

[FIX] mixins.connectors: raise if not connected

[FIX] Set current log level in commands arguments

[IMP] test.common.odev: test upgrade features

[ADD] commands.kill: kill a running odoo-bin process

Add a new class for representing an odoo-bin process and interacting
with it.

[ADD] commands.run: draft for run command starting an odoo-bin process

[IMP] flake8 and pre-commit config

Ignore unused imports in `__init__.py` files and type check methods with
untyped definition.

[IMP] upgrades 4.0.0: combine directory paths

Merge standard and custom directories together under a single path.

[IMP] setup.directories: merge directories into one

[IMP] databases.postgres: Add helper methods for common SQL operations

And other misc. changes.

[IMP] connectors.postgres: add helper methods and improve caching

LRU caching from functools was used to cache all SQL queries. This
was not a good idea because it was not possible to invalidate the
cache and it was not efficient because of context managers which made
the `self` object to be generated each time a new connection was open.

The commit adds a simple cache system which can be bypassed easily
by setting the `nocache` attribute to `True`. Only `SELECT` statements
are cached to let alteration statements to be executed at all times.

[IMP] mixins.connectors: Split connector mixins into their own files

Remove the dynamic generation of custom attributes typing, let
the developers handle it.

[IMP] common.config: Add repr and global config object

[IMP] common.logging: Context manager to silence loggers temporarily

[IMP] common: Add repr to misc classes

[IMP] main and setup: use the global config instance

[ADD] Github connector and secrets vault

New connector to the Github API and to manage local Git repositories.
Handles the clone and pull of repositories, and the creation of
worktrees.

The secrets vault is a new module to manage credentials and secrets
in a secure way. It uses the the local SSH agent to encrypt secrets
and stores them in a local PostgreSQL database.

[IMP] common.bash: new method to stream output

Add a new `bash::stream` method to capture output of a subprocess
line by line, allowing to manipulate data as it is being generated.

[IMP] common.python: improvements to requirements installation

Allow to find out if requirements are missing or already installed.
Display progress while installing packages from a `requirements.txt`
file.

[ADD] odev.common.commands.odoobin: Add odoobin command class

New class to interact with local databases through odoo-bin.
Add new helper methods in `common.odoo` to setup virtual environments
and Git worktrees automatically before running odoo-bin.

[ADD] commands.run: Run a local odoo database through odoo-bin

[IMP] commands.kill: adapt kill to use OdoobinCommand

[FIX] Tests

[IMP] Synchronize repositories and worktrees if deleted from elsewhere

When a repository is removed from the filesystem `odev` will attempt
to clone it anew. This might lead to errors when creating worktrees
if the old worktree directory is still present. This commit checks
for existing worktrees and removes them before cloning the repository.

When a worktree is removed from the filesystem but is still referenced
in Git, `odev` will attempt to load and use it. This might lead to
errors where we are loading a non-existing path. This commit checks
for existing worktrees references and removes them before re-creating
the worktree.

Because fetching changes in repositories is done in a detached process,
`odev` does not wait for the process to end before running the next
operation. If a call to :func:`fetch` or :func:`fetch_worktrees` is
followed by a call to :func:`pull` or :func:`pull_worktrees`, the fetch
subprocess might still be running when the pull is executed. This leads
to situations where the pull is executed on a repository that is not
entirely fetched yet and Git raises an error stating that rebase cannot
be performed on two different branches at once. This commit inverts
calls to fetch and pull so that the fetch is always executed *after* the
call to git pull. Changes pulling might be delayed until the next time
`odev` is run.

[ADD] command.shell: support for `odoo-bin shell`

Allow passing `odoo-bin` subcommands to :func:`OdooBinProcess.run()`.

[ADD] commands.cloc: Count custom lines of code in Odoo databases

Adapt the old `odev cloc` command to the new framework with display
improvements and spinner during loading of information.

Add spinners on several time-consuming operations like preparation of
virtual environments before running `odoo-bin`.

[IMP] Add checks on existing and running odoo-bin databases

Prevents calling commands if conditions on existing and running
databases are not met.

[IMP] Requirements and forcing enterprise edition on OdooBinProcess

Improve `requirements.txt` installation in python virtual environments
and add default packages to each environment to avoid manual
intervention on each first run in the environment.

Also, force the use of enterprise edition when using OdooBinProcess
if a command is run with the `--enterprise` flag.

fixup

[ADD] Context manager for spinner animations on long running tasks

[IMP] SQL queries context

Run SQL queries in transactions and rollback if necessary

Make sure SQL queries are surrounded by `BEGIN` and `COMMIT` statements
(or `ROLLBACK` if an error ocurred).

Queries are now run in a new thread to allow cancelling long running
operations (i.e. creating a database from a large template). This is
an improvement for security and user experience, not performance hence
the thread is called in a blocking way and no code is executed
in parallel in the parent thread.

[ADD] commands.create: Create and initialize databases

[IMP] Allow forcing Odoo version to run odoo-bin

A version can be provided to odoo-bin commands to force the version used
which also allows to run odoo-bin with the master version.

[ADD] Commands history

Keep an history of the commands executed and there last execution date.

This enables knowing when a command was last run on a database and
provides more accurate "last access" information for the `list` command.

[IMP] Framework improvements:

Split `PostgresDatabase` into `LocalDatabase` and `PostgresDatabase`
to allow reusability of the `PostgresDatabase` class for other
non-Odoo databases.

Make the Odev framework global and accessible from anywhere through
the `OdevFrameworkMixin` mixin class. This adds easy to access
properties for the configuration and the datastore.

Move datastore models to a new store instance with a more consistent way
of creating and accessing tables.

Harmonize the use of properties instead of methods when possible.

[FIX] Check if database exists before checking if it is an Odoo database

[FIX] Remove `nargs` key in `create` command arguments

[FIX] Handle partially initialized databases

Databases that have been killed before the base Odoo module
was properly installed have no version number while the row exists
in Postgres. This commit handles this case by forcing the version number
to `None` if a result was returned with no value.

[IMP] Double confirmation before removing whitelisted databases

[IMP] Harmonize logger and include loading time in performance log

Use `logger` instead of `_logger` in `__main__.py` and `__setup__.py`
to keep consistent with other files in the framework.

Also, include the loading time in the performance log and dynamically
import the framework to measure the time it takes.

[ADD] commands.database.test: Run tests on an empty copy of the database

Copy the selected database configuration and initialize a new database
with no data. Install the selected modules and run unit tests.
Capture the output and display it in the terminal and keep track
of failing tests to display a summary at the end of the command.
Delete the test database after the tests have been run.

Odoo-bin and other python scripts can be run with a progress callback
that is called on every line outputted to STDOUT or STDERR
by the script.

[ADD] commands.database.rename: Add command to rename a local database

Alter the name of the database in PostgreSQL and in the data store.
Move the filestore to its new logical location.

[IMP] Improve progress display and avoid multiple live-display errors

Override Rich's Status class to avoid multiple live-display errors
by stacking spinners and pausing them when a new one is started
and resuming them when the last one is finished.

Also, add a new Progress class to display a progress bar with default
styling applied. The progress also automatically pauses running spinners
and resumes them after completion.

[FIX] store.secrets is a table and not a database

Call queries on the `odev` database instead of the old `secrets`
database that does not exist anymore.

[REM] Remove the old `rename` command

[IMP] databases: uniformize database classes (prepare remote connectors)

Add a `platform` attribute on database classes.

Uniformize database classes methods by adding default methods
and properties to the base `Database` class.

[IMP] databases: unaccented schema in database class

Move the creation of the `unaccent` schema to the database class
instead of the `create` command.

[IMP] commands.list: Display totals under size columns

Count the number of databases and add a total row under the database
list table.

[IMP] commands: Move database existence check to DatabaseCommand

[IMP] databases: dump a local database

Allow creation of a dump of a local database on the filesystem.

[FIX] Gracefully handle errors during arguments parsing

[IMP] Do not update secrets when not changed

[FIX] Do not fetch database info for non-existing local databases

[ADD] databases.saas: Support for SaaS databases

Add a SaaS connector to interact with `_odoo/support` pages using stored
credentials.

Add a SaaS database class with access to the connector.

Infer the database type from the name passed to `DatabaseCommand`
instances.

[ADD] com…
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
7 participants