summaryrefslogtreecommitdiffstats
path: root/config-model-api/src/test/java/com/yahoo/config/application/api/ValidationOverrideTest.java
blob: 2528fe8883e6c3ec83b47401639c167d262c9478 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.config.application.api;

import com.yahoo.config.application.api.ValidationId;
import com.yahoo.config.application.api.ValidationOverrides;
import com.yahoo.test.ManualClock;
import org.junit.Assert;
import org.junit.Test;
import org.xml.sax.SAXException;

import java.io.IOException;
import java.io.StringReader;
import java.util.Optional;

import static org.junit.Assert.fail;
import static org.junit.Assert.assertEquals;

/**
 * @author bratseth
 */
public class ValidationOverrideTest {

    @Test
    public void testValidationOverridesInIsolation() throws IOException, SAXException {
        String validationOverrides =
                "<validation-overrides>" +
                "  <allow until='2000-01-01'>indexing-change</allow>" +
                "  <allow until='2000-01-03' comment='any text'>indexing-mode-change</allow>" +
                "</validation-overrides>";

        {

            ValidationOverrides overrides = ValidationOverrides.read(Optional.of(new StringReader(validationOverrides)),
                                                                                 ManualClock.at("2000-01-01T23:59:00"));
            assertOverridden("indexing-change", overrides);
            assertOverridden("indexing-mode-change", overrides);
            assertNotOverridden("field-type-change", overrides);
        }

        {
            ValidationOverrides overrides = ValidationOverrides.read(Optional.of(new StringReader(validationOverrides)),
                                                                                 ManualClock.at("2000-01-02T00:00:00"));
            assertNotOverridden("indexing-change", overrides);
            assertOverridden("indexing-mode-change", overrides);
            assertNotOverridden("field-type-change", overrides);
        }

        {
            ValidationOverrides overrides = ValidationOverrides.read(Optional.of(new StringReader(validationOverrides)),
                                                                                 ManualClock.at("2000-01-04T00:00:00"));
            assertNotOverridden("indexing-change", overrides);
            assertNotOverridden("indexing-mode-change", overrides);
            assertNotOverridden("field-type-change", overrides);
        }

    }

    @Test
    public void testInvalidOverridePeriod() throws IOException, SAXException {
        String validationOverrides =
                "<validation-overrides>" +
                "  <allow until='2000-02-02'>indexing-change</allow>" +
                "</validation-overrides>";

        try {
            ValidationOverrides.read(Optional.of(new StringReader(validationOverrides)),
                                                 ManualClock.at("2000-01-01T23:59:00"));
            Assert.fail("Expected validation interval override validation validation failure");
        }
        catch (IllegalArgumentException e) {
            Assert.assertEquals("validation-overrides is invalid", e.getMessage());
            Assert.assertEquals("allow 'indexing-change' until 2000-02-03T00:00:00Z is too far in the future: Max 30 days is allowed",
                                e.getCause().getMessage());
        }
    }

    private void assertOverridden(String validationId, ValidationOverrides overrides) {
        overrides.invalid(ValidationId.from(validationId).get(), "message"); // should not throw exception
    }

    private void assertNotOverridden(String validationId, ValidationOverrides overrides) {
        try {
            overrides.invalid(ValidationId.from(validationId).get(), "message");
            Assert.fail("Expected '" + validationId + "' to not be overridden");
        }
        catch (ValidationOverrides.ValidationException expected) {
        }
    }

}