|
28 | 28 | use Patchlevel\EventSourcing\Subscription\Engine\DefaultSubscriptionEngine; |
29 | 29 | use Patchlevel\EventSourcing\Subscription\Engine\EventFilteredStoreMessageLoader; |
30 | 30 | use Patchlevel\EventSourcing\Subscription\Engine\GapResolverStoreMessageLoader; |
| 31 | +use Patchlevel\EventSourcing\Subscription\Engine\MessageLoader; |
31 | 32 | use Patchlevel\EventSourcing\Subscription\Engine\StoreMessageLoader; |
32 | 33 | use Patchlevel\EventSourcing\Subscription\Engine\SubscriptionEngineCriteria; |
33 | 34 | use Patchlevel\EventSourcing\Subscription\RetryStrategy\ClockBasedRetryStrategy; |
@@ -1565,6 +1566,72 @@ public function testLookup(): void |
1565 | 1566 | self::assertSame('Hans', $result['name']); |
1566 | 1567 | } |
1567 | 1568 |
|
| 1569 | + public function testRefreshSubscriptions(): void |
| 1570 | + { |
| 1571 | + $store = new DoctrineDbalStore( |
| 1572 | + $this->connection, |
| 1573 | + DefaultEventSerializer::createFromPaths([__DIR__ . '/Events']), |
| 1574 | + ); |
| 1575 | + |
| 1576 | + $clock = new FrozenClock(new DateTimeImmutable('2021-01-01T00:00:00')); |
| 1577 | + |
| 1578 | + $subscriptionStore = new DoctrineSubscriptionStore( |
| 1579 | + $this->connection, |
| 1580 | + $clock, |
| 1581 | + ); |
| 1582 | + |
| 1583 | + $schemaDirector = new DoctrineSchemaDirector( |
| 1584 | + $this->connection, |
| 1585 | + new ChainDoctrineSchemaConfigurator([ |
| 1586 | + $store, |
| 1587 | + $subscriptionStore, |
| 1588 | + ]), |
| 1589 | + ); |
| 1590 | + |
| 1591 | + $schemaDirector->create(); |
| 1592 | + |
| 1593 | + $subscriber = new #[Subscriber('test', RunMode::FromBeginning, group: 'default')] |
| 1594 | + class { |
| 1595 | + }; |
| 1596 | + |
| 1597 | + $subscriberRepository = new MetadataSubscriberAccessorRepository([$subscriber]); |
| 1598 | + |
| 1599 | + $engine = new DefaultSubscriptionEngine( |
| 1600 | + $this->createMock(MessageLoader::class), |
| 1601 | + $subscriptionStore, |
| 1602 | + $subscriberRepository, |
| 1603 | + ); |
| 1604 | + |
| 1605 | + $engine->setup(); |
| 1606 | + |
| 1607 | + $subscriptions = $engine->subscriptions(); |
| 1608 | + self::assertCount(1, $subscriptions); |
| 1609 | + self::assertEquals('test', $subscriptions[0]->id()); |
| 1610 | + self::assertEquals('default', $subscriptions[0]->group()); |
| 1611 | + self::assertEquals(RunMode::FromBeginning, $subscriptions[0]->runMode()); |
| 1612 | + |
| 1613 | + // change subscriber metadata |
| 1614 | + $newSubscriber = new #[Subscriber('test', RunMode::FromNow, group: 'new-group')] |
| 1615 | + class { |
| 1616 | + }; |
| 1617 | + |
| 1618 | + $newSubscriberRepository = new MetadataSubscriberAccessorRepository([$newSubscriber]); |
| 1619 | + |
| 1620 | + $engine = new DefaultSubscriptionEngine( |
| 1621 | + $this->createMock(MessageLoader::class), |
| 1622 | + $subscriptionStore, |
| 1623 | + $newSubscriberRepository, |
| 1624 | + ); |
| 1625 | + |
| 1626 | + $engine->refresh(); |
| 1627 | + |
| 1628 | + $subscriptions = $engine->subscriptions(); |
| 1629 | + self::assertCount(1, $subscriptions); |
| 1630 | + self::assertEquals('test', $subscriptions[0]->id()); |
| 1631 | + self::assertEquals('new-group', $subscriptions[0]->group()); |
| 1632 | + self::assertEquals(RunMode::FromNow, $subscriptions[0]->runMode()); |
| 1633 | + } |
| 1634 | + |
1568 | 1635 | /** @param list<Subscription> $subscriptions */ |
1569 | 1636 | private static function findSubscription(array $subscriptions, string $id): Subscription |
1570 | 1637 | { |
|
0 commit comments