8

I have the following code:

Get.put(DbController(HabitDao(AppDb())));

When I hot reload my app, I get the following error:

"WARNING (moor): It looks like you've created the database class AppDb multiple times. When these two databases use the same QueryExecutor, race conditions will occur and might corrupt the database."

I need to check if I have put a DbController before creating a new AppDb instance. I never had this problem while using the Provider package.

What is the best practice to solve this?

M. Azyoksul
  • 1,580
  • 2
  • 16
  • 43

2 Answers2

37

You can check with Get.isRegistered.

For your code:

bool test = Get.isRegistered<DbController>(tag: 'TagInPut');

If you didn't use tag, you can delete it.

bool test = Get.isRegistered<DbController>();
Atakan Akbulut
  • 620
  • 1
  • 9
  • 15
0

You may find this useful while writing widget test when you want to use your mocked controller instead of putting a controller in screen

late ParentProfileController controller;

  @override
  void initState() {
    if (Get.isRegistered<ParentProfileController>()) {
      controller = Get.find<ParentProfileController>();
    } else {
      controller = Get.put(ParentProfileController());
    }
    super.initState();
  }
Akshay Bengani
  • 37
  • 2
  • 10