File: Issue986.java

package info (click to toggle)
checker-framework-java 3.2.0%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 23,104 kB
  • sloc: java: 145,916; xml: 839; sh: 518; makefile: 404; perl: 26
file content (35 lines) | stat: -rw-r--r-- 1,281 bytes parent folder | download | duplicates (3)
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
// Test case for issue #986:
// https://github.com/typetools/checker-framework/issues/986

// @skip-test until the issue is fixed

public class Issue986 {

    public static void main(String[] args) {
        String array[] = new String[3];
        array[0].length(); // NPE here
    }

    // Flow should refine @MonotonicNonNull component types to @NonNull.
    void testArr4(@NonNull Object @NonNull [] nno1, @MonotonicNonNull Object @NonNull [] lnno1) {
        @MonotonicNonNull Object[] lnno2;
        @NonNull Object[] nno2;
        nno2 = nno1;
        lnno2 = lnno1;
        lnno2 = nno1;
        // :: error: (assignment.type.incompatible)
        nno2 = lnno1;
        lnno2 = NullnessUtil.castNonNullDeep(nno1);
        nno2 = NullnessUtil.castNonNullDeep(lnno1);
        lnno2 = NullnessUtil.castNonNullDeep(nno1);
        nno2 = NullnessUtil.castNonNullDeep(lnno1);
    }

    // Flow should refine @MonotonicNonNull component types to @NonNull.
    // This is a prerequisite for issue #986 (or for workarounds to issue #986).
    void testArr5(@MonotonicNonNull Object @NonNull [] a) {
        @MonotonicNonNull Object[] l5 = NullnessUtil.castNonNullDeep(a);
        @NonNull Object[] l6 = l5;
        @NonNull Object[] l7 = NullnessUtil.castNonNullDeep(a);
    }
}