Enhanced seeding system #1072
Replies: 4 comments
-
Key difference to migrations: Besides the features I want to implement there is one other key difference: migrations are keept inside another folder/crate which does not allow me to access my custom code inside them so it only makes them useful for basic schema migration. In my case: |
Beta Was this translation helpful? Give feedback.
-
Had you both time to look at this? |
Beta Was this translation helpful? Give feedback.
-
@DenuxPlays I'm looking forward to hearing more feedback from the community here. |
Beta Was this translation helpful? Give feedback.
-
Perhaps it’s worth using trait Environment instead of a hard-coded enum with test, dev, prod environment. pub trait Environment {
fn get_name() -> &'static str;
fn is_allow_seed() -> bool;
fn is_allow_truncate() -> bool;
async fn load_config() -> Result<Config, Error>;
async fn seed() -> Result<(), Error>;
async fn truncate() -> Result<(), Error>;
async fn logger_init() -> Result<(), Error>;
} we can use this for tests too, to reproduce some application environment I feel like this will solve a bunch of different problems |
Beta Was this translation helpful? Give feedback.
-
Hey,
since I created two prs regarding to improve the seeding system and a few questions came up I wanted to focus my motivation here.
My plan is to improve the seeding system to have something like symfony fixtures.
Currently it is only possible to seed via files which will fail if you need to generate data/ids or execute other code somehow.
So my first pr is to allow the execution of rust code.
My second pr was to pass AppContext to the seed function instead of just the db to allow more functionality to the user.
Further plans are:
This would immensely improve the dx and the whole fixtures/seeding feature of loco.
But it would also introduce a few breaking changes (change the file format of the seeding file to add the ability to add tags and env requirements and ofcourse the change from the DatabaseConnection to AppContext)
Ofcourse would be available to create prs and maintain the features in the future.
And ofcourse everything can be implemented by using the hooks but I think more users can take advantage of it which is why I am proposing it as a new feature.
CC: @kaplanelad
Ref issues:
seed
function inHook
should get AppContext as an argument. #1060Ref prs:
Beta Was this translation helpful? Give feedback.
All reactions