@Test @UsingDataSet( locations = "EsIndexRangeServiceTest.json", loadStrategy = LoadStrategyEnum.CLEAN_INSERT) public void savePersistsIndexRangeInReadOnlyIndex() throws Exception { final String indexName = "graylog_read_only"; final DateTime begin = new DateTime(2015, 1, 1, 0, 0, DateTimeZone.UTC); final DateTime end = new DateTime(2015, 1, 2, 0, 0, DateTimeZone.UTC); final DateTime now = DateTime.now(DateTimeZone.UTC); final IndexRange indexRange = IndexRange.create(indexName, begin, end, now, 42); try { indices.create(indexName); indices.setReadOnly(indexName); assumeTrue(indices.isReadOnly(indexName)); indexRangeService.save(indexRange); verify(clusterEventBus, times(1)).post(IndexRangeUpdatedEvent.create(indexName)); assertThat(indices.isReadOnly(indexName)).isTrue(); final IndexRange result = indexRangeService.get(indexName); assertThat(result.indexName()).isEqualTo(indexName); assertThat(result.begin()).isEqualTo(begin); assertThat(result.end()).isEqualTo(end); assertThat(result.calculatedAt()).isEqualTo(now); assertThat(result.calculationDuration()).isEqualTo(42); } finally { indices.delete(indexName); } }