thosakwe/feathers-seeder

Reset autoincrement value for sequelize-adapter

Opened this issue · 4 comments

The primary field auto increment value is not resetted on delete operation, thus when seeding the app the first time and creating 1 user he will have the id 1. After restarting node.js and seeding again, the database is clean but the id of the user is 2.

Currently with the callback one can store the ids of entities to dynamically set the correct relationships in later services(e.g. if i want to relate an item to the first user i created i need to know the userId). But to make life simpler, it would be great if the auto increment value is resetted, because one can then easier prototype the config, without having to make sure to not use hard-coded ids.

One remark: For now i'm just setting the id field manually myself to make sure it has a certain id. So this issue is not on high priority.

Perhaps I can add a hooking option to the seed function, like:

const seederConfig = {
  services: [...],
  hooks: {
    after: {
      delete() {
        return new Promise((resolve, reject) => {
          resetAutoIncrement((err) => {
            // ...
          });
        });
      }
    }
  }
};

I want to keep the seeder provider-agnostic, so this would probably be the best method to maintain that.

I agree with @thosakwe here. feathers-seeder just deals with services and not those types of concerns.

Can you have sequelize drop/create the db before seeding?

Sure feathers shouldn't be aware of any implementation details of the service adapters. But the hook would be great!