1 /*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * https://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17 package org.apache.commons.validator.routines.checkdigit;
18
19 import static org.junit.jupiter.api.Assertions.assertFalse;
20
21 import org.junit.jupiter.api.BeforeEach;
22 import org.junit.jupiter.api.Test;
23
24 /**
25 * ISIN Check Digit Test.
26 */
27 class ISINCheckDigitTest extends AbstractCheckDigitTest {
28
29 private static final String[] INVALID_CHECK_DIGITS = { "US037833100O", // proper check digit is '5', see above
30 "BMG8571G109D", // proper check digit is '6', see above
31 "AU0000XVGZAD", // proper check digit is '3', see above
32 "GB000263494I", // proper check digit is '6', see above
33 "FR000402625C", // proper check digit is '0', see above
34 "DK000976334H", // proper check digit is '4', see above
35 };
36
37 /**
38 * Sets up routine & valid codes.
39 */
40 @BeforeEach
41 protected void setUp() {
42 routine = ISINCheckDigit.ISIN_CHECK_DIGIT;
43 valid = new String[] { "US0378331005", "BMG8571G1096", "AU0000XVGZA3", "GB0002634946", "FR0004026250", "3133EHHF3", // see VALIDATOR-422 Valid
44 // check-digit, but not valid ISIN
45 "DK0009763344", "dk0009763344", // TODO lowercase is currently accepted, but is this valid?
46 "AU0000xvgza3", // lowercase NSIN
47 "EZ0000000003", // Invented; for use in ISINValidatorTest
48 "XS0000000009", // ditto
49 "AA0000000006", // ditto
50 };
51 invalid = new String[] { "0378#3100" };
52 }
53
54 @Test
55 void testValidator345() {
56 for (final String invalidCheckDigit : INVALID_CHECK_DIGITS) {
57 assertFalse(routine.isValid(invalidCheckDigit), "Should fail: " + invalidCheckDigit);
58 }
59 }
60 }