Skip to content

Conversation

@duncanmcclean
Copy link
Member

@duncanmcclean duncanmcclean commented Mar 7, 2024

This pull request changes the way migrations are published so they use fixed timestamps, to prevent issues where the same migrations could be published multiple times.

When you run the vendor:publish command and attempt to publish something which has already been published, Laravel will ignore publishing the file and give you a warning.

However, in the case of the Eloquent driver, because our "destination filename" was dynamic based on the current date & time, the filename Laravel would check against would never match up to an existing migration. This could lead to the same migration being published multiple times.

While Laravel 11 does include a new publishesMigrations method (introduced in laravel/framework#49246), which replaces the timestamps in migration filenames, it has the same pitfall we were running into before in that it doesn't check for existence for past migrations.

This PR adjusts how migrations are published so all the migrations have a fixed timestamp, rather than a dynamic one so Laravel can recognise any duplicates before publishing.

I adjusted the name of the migration files themselves (not the stubs in updates though) and also moved the migration code into a new publishMigrations method to tidy things up a little.

@duncanmcclean duncanmcclean marked this pull request as draft March 7, 2024 12:06
@duncanmcclean duncanmcclean changed the title Use fixed timestamps in migration filenames Prevent migrations being published multiple times Mar 7, 2024
@duncanmcclean duncanmcclean marked this pull request as ready for review March 7, 2024 13:07
@ryanmitchell
Copy link
Contributor

Seems good. Do you want it merged or is the plan to hold off for v5?

@duncanmcclean
Copy link
Member Author

Seems good. Do you want it merged or is the plan to hold off for v5?

Yeah, let's get it merged, it'll allow for testing the Core PR. Just wanted to check it looked good for you before merging since I've haven't touched this package much 😄

@duncanmcclean duncanmcclean merged commit 3fb33e5 into master Mar 7, 2024
@duncanmcclean duncanmcclean deleted the use-fixed-dates-in-migration-names branch March 7, 2024 17:42
@marvinosswald
Copy link

This causes issues with existing installations as my system now tries to migrate all of those again as the name changed from 2024_02_07... to 2024_03_07... am i overseeing something i should do differently ?

@potsky
Copy link

potsky commented Mar 8, 2024

Me too @marvinosswald.

The migrations seem to be loaded from the package now. So I have removed all targeted migrations from our repository and have renamed the migrations in the migrations table with this PostgreSQL query:

UPDATE migrations
SET migration='2024_03_07_100000' || SUBSTRING (migration, '^2024_01_09_[0-9]{6}(_create.*$)')
WHERE migration LIKE '2024_01_09_%_create_%_table';

Change the 2024_01_09 date with your installation date of course!

@duncanmcclean Can you confirm we need to do this?

@duncanmcclean
Copy link
Member Author

When are the migrations being re-published? When you run composer update?

@marvinosswald
Copy link

https://github.com/statamic/eloquent-driver/pull/253/files#diff-abf1fa77a19f720052b75bc802df0260157b9064d8c3c12a80794f01e9acc065L216

Doesn't need to be republished for this problem.
this is the problematic line, this makes laravel "discover" the migrations without them being published afaik.

@duncanmcclean
Copy link
Member Author

duncanmcclean commented Mar 8, 2024

Doesn't need to be republished for this problem.
this is the problematic line, this makes laravel "discover" the migrations without them being published afaik.

That line is only related to loading the migrations within the test suite, it won't affect "real" applications.

@duncanmcclean
Copy link
Member Author

duncanmcclean commented Mar 8, 2024

Ah, I've figured it out...

In addition to letting you publish the migrations yourself into your database/migrations directory, the Eloquent Driver is also directly loading the migration files from it's database/migrations directory, which leads to errors when running php artisan migrate.

I've opened a PR which fixes it (#255), which I'll tag a release for shortly.

@duncanmcclean
Copy link
Member Author

It should hopefully be fixed in v3.3.1. Thanks!

duncanmcclean added a commit to statamic/cms that referenced this pull request Mar 15, 2024
Once statamic/eloquent-driver#253 has been merged, it won't be possible for the same migration to be published multiple times so this will no longer be an issue.
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 this pull request may close these issues.

4 participants