|
21 | 21 | use Drupal\Core\Logger\RfcLogLevel; |
22 | 22 | use Drupal\KernelTests\KernelTestBase; |
23 | 23 | use Drupal\Tests\collabora_online\Traits\KernelTestLoggerTrait; |
| 24 | +use Drupal\Tests\collabora_online\Traits\KernelTestTimeTrait; |
24 | 25 | use GuzzleHttp\Client; |
25 | 26 | use GuzzleHttp\Exception\TransferException; |
26 | 27 | use GuzzleHttp\Psr7\Response; |
|
31 | 32 | class DiscoveryFetcherTest extends KernelTestBase { |
32 | 33 |
|
33 | 34 | use KernelTestLoggerTrait; |
| 35 | + use KernelTestTimeTrait; |
34 | 36 |
|
35 | 37 | /** |
36 | 38 | * XML content to be returned for a discovery request. |
@@ -158,9 +160,38 @@ public function testGetDiscoveryIsCached(): void { |
158 | 160 | ->save(); |
159 | 161 |
|
160 | 162 | $fetcher->getDiscovery(); |
| 163 | + $this->assertCount(3, $this->httpClientGetCalls); |
161 | 164 | $cache_record = $load_cache(); |
162 | 165 | $this->assertNotFalse($cache_record); |
163 | 166 | $this->assertSame(12345, $cache_record->expire - $cache_record->created); |
| 167 | + |
| 168 | + $this->mockRequestTime = $this->mockRequestTime->add(new \DateInterval('PT12330S')); |
| 169 | + |
| 170 | + $this->assertSame(12330, $this->mockRequestTime->getTimestamp() - $cache_record->created); |
| 171 | + $this->assertNotFalse($load_cache()); |
| 172 | + |
| 173 | + $fetcher->getDiscovery(); |
| 174 | + $this->assertCount(3, $this->httpClientGetCalls); |
| 175 | + |
| 176 | + $this->mockRequestTime = $this->mockRequestTime->add(new \DateInterval('PT30S')); |
| 177 | + |
| 178 | + $this->assertFalse($load_cache()); |
| 179 | + $this->assertSame(12360, $this->mockRequestTime->getTimestamp() - $cache_record->created); |
| 180 | + |
| 181 | + $fetcher->getDiscovery(); |
| 182 | + $this->assertCount(4, $this->httpClientGetCalls); |
| 183 | + |
| 184 | + // Set TTL = 0 for no cache, always refresh. |
| 185 | + $this->config('collabora_online.settings') |
| 186 | + ->set('cool.discovery_cache_ttl', 0) |
| 187 | + ->save(); |
| 188 | + $fetcher->getDiscovery(); |
| 189 | + $this->assertCount(5, $this->httpClientGetCalls); |
| 190 | + $fetcher->getDiscovery(); |
| 191 | + $this->assertCount(5, $this->httpClientGetCalls); |
| 192 | + $this->mockRequestTime = $this->mockRequestTime->add(new \DateInterval('PT1S')); |
| 193 | + $fetcher->getDiscovery(); |
| 194 | + $this->assertCount(6, $this->httpClientGetCalls); |
164 | 195 | } |
165 | 196 |
|
166 | 197 | /** |
|
0 commit comments