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

node ace db:truncate throws the error deadlock detected #1027

Open
mdsadiqueinam opened this issue May 11, 2024 · 5 comments
Open

node ace db:truncate throws the error deadlock detected #1027

mdsadiqueinam opened this issue May 11, 2024 · 5 comments

Comments

@mdsadiqueinam
Copy link
Contributor

mdsadiqueinam commented May 11, 2024

Package version

@adonisjs/[email protected]

Describe the bug

node ace db:truncate throws the error deadlock detected but when I run all truncate queries from Datagrip console it runs successfully

Reproduction repo

No response

Proof of error

Screencast.2024-05-13.16.14.16.mp4
@mdsadiqueinam
Copy link
Contributor Author

mdsadiqueinam commented May 13, 2024

Hi @thetutlage 👋
Added the proof of error in the description of this issue

@diego-sepulveda-lavin
Copy link

I'm experiencing the same issue with node ace db:truncate and setup: [() => testUtils.db().truncate()]

I've tested the same database schema in both postgres and mysql (around 40 tables). While everything works fine in mysql and tables get truncated without problems, I'm encountering the issue with the truncate command inpostgres.

Specifically, the command finds a deadlock in postgres, and I believe this is due to the way Lucid executes the TRUNCATE tablename CASCADE concurrently for all tables.

Basically, the command will get all tablenames from the DB and then will execute Promise.all[table_a, table_b,...]

Captura de pantalla 2024-08-12 a la(s) 9 48 34 a  m

Depending on the table names and the relations between them, you might get a deadlock (image table_c) if its parents (table_a and table_b) are getting truncated at the same time, because they will be locking their children.

Captura de pantalla 2024-08-12 a la(s) 9 44 27 a  m

I've also tested what OP mentions (running truncate sequentially inside a for loop) and the issue is gone, but the best solution in my opinion would be what PostgreSQL documentation here mentions, where using a single TRUNCATE command that includes all the tables is recommended, which would avoid the locking issue.
I have tested TRUNCATE table_a, table_b, table_c, ... [other options]; and it works perfectly!

@Dyoma3
Copy link

Dyoma3 commented Oct 21, 2024

I'm having the same issue with running group.setup(() => testUtils.db().truncate()) on a test.group.

@RomainLanz
Copy link
Member

Hey all! 👋🏻

@diego-sepulveda-lavin, may you send a PR with a failing test and a change in the PSQL dialect to use only one TRUNCATE call?

@thetutlage
Copy link
Member

Yeah, a PR will be appreciated

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants