diff --git a/changelogs/unreleased/4834-acquire-lock-on-correct-db-table.yml b/changelogs/unreleased/4834-acquire-lock-on-correct-db-table.yml new file mode 100644 index 0000000000..051b22bb14 --- /dev/null +++ b/changelogs/unreleased/4834-acquire-lock-on-correct-db-table.yml @@ -0,0 +1,6 @@ +--- +description: Fix bug where a cascading delete of an environment causes a deadlock because it acquires a table-level lock on an incorrect database table. +issue-nr: 4834 +issue-repo: inmanta-core +change-type: patch +destination-branches: [master, iso5] diff --git a/src/inmanta/data/__init__.py b/src/inmanta/data/__init__.py index 6586c173f7..953f74d044 100644 --- a/src/inmanta/data/__init__.py +++ b/src/inmanta/data/__init__.py @@ -5573,7 +5573,7 @@ async def delete_cascade(self) -> None: await Code.delete_all(connection=con, environment=self.environment, version=self.version) # Acquire explicit lock to avoid deadlock. See ConfigurationModel docstring - await self.lock_table(TableLockMode.SHARE, connection=con) + await ResourceAction.lock_table(TableLockMode.SHARE, connection=con) await Resource.delete_all(connection=con, environment=self.environment, model=self.version) # Delete facts when the resources in this version are the only