OopNegativeSemanticTest.ttcn 4.07 KB
Newer Older
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
/******************************************************************************
 * Copyright (c) 2000-2021 Ericsson Telecom AB
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v2.0
 * which accompanies this distribution, and is available at
 * https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.html
 *
 * Contributors:
 *   Magyari, Miklos
 *
 ******************************************************************************/

module classesNegativeSemantic { 

type component CT {
	port PT pt_PT;
}

type port PT message { inout integer; } with { extension "internal" }

type union MyUnion {
	integer a,
	charstring b
};

type class CorrectClass1 { }

type class BadInheritance extends MyUnion {

}

32
33
type class SuperClass {
	var integer vl_a;
34
	template MyUnion t_union := { a := 10 }
35
}
36
37

type class SubClass extends SuperClass {
38
	public var integer vl_b;
39
40
41
42
}

type class GrandSubClass extends SubClass {
	var integer vl_c;
43
	template MyUnion t_union2 := { nonexist := 10 }		// non-existing template member
44
45
46
47
48
49
50
51
52
53
54
55
}

type class GrandSubClass2 extends SubClass {
	var charstring vl_b;
}

type class BaseFunctionClass {
	public function f_get_one() return integer {
		return 1; 
	}
}

56
type class OuterClass {
57
	private var integer m_int := 0; 
58
59
60
61
62
63
64
65
66
67
68

	class NestedClass {
		const charstring c_text := "abc";

		class InnerClass {
			private template MyUnion t_union;
			public var integer badInteger := "xyz";
		}
	}
}

69
70
71
72
73
74
75
76
77
78
type class ReuseClass {
	var charstring vl_orig := "abc";
	
	function f_reuse_id(in integer pl_param) {
		var integer vl_orig := 1;
		vl_orig := 2;
		vl_orig := "abc";	// type mismatch: local definition takes precedence
	}
}

79
80
const integer cg_uninitConst1;

81
82
type class SubFunctionClass extends BaseFunctionClass {  
	private const integer m_const := 1;
83
	private const integer m_uninitConst2;
84
85
86
87
88
	public function f_get_one() return integer {		// FIXME : incomplete marker
		return m_const;
	}
}

89
90
91
92
// an abstract class can have a finally block
type class @abstract FinallyClass {
	public const integer m_const := 0;
} finally {
93
	log(this.m_const);
94
95
96
97
98
99
}

// a trait class cannot have a finally block
type class @trait FinallyClass2 {
	public const integer m_const := 0;
} finally {
100
	log(this.m_const);
101
102
}

103
104
105
106
107
// bad combination of class modifiers
type class @final @abstract BadClass1 { }
type class @final @trait BadClass3 { }
type class @abstract @trait BadClass2 { }

108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
// class with this
type class ClassWithThis {
	public var integer vl_a;
	const float vl_b;

	public function pl_dummy(in integer pl_int) return integer {
		return 1;
	}

	public function f_dummy2(in charstring pl_dummy) {
		var charstring vl_int := this.pl_dummy(1);
	}
	
	create (integer a, float b) {
		this.a := vl_a;
		this.b := vl_b;
	}
}

127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
function f_fake_super() return charstring {
	return "abc";
}

// bad super references
function f_notinclass(in integer pl_int) {
	var charstring vl_ch := super.f_fake_super();
}

type class FuncClass extends BaseFunctionClass {
	public function f_get_one() return charstring {
		return "xyz";
	}
	
	private function f_test_super() {
	  	// type mismatches 
		var integer vl_int := f_get_one();
		var charstring vl_cs:= super.f_get_one();
	}
}

148
149
150
151
152
153
154
155
156
testcase tc_basicSyntax() runs on CT {
	var GrandSubClass vl_gsc := GrandSubClass.create;
	
	var integer vl_int1 := vl_gsc.vl_c;		// correct : own class member
	var integer vl_int2 := vl_gsc.vl_b;		// correct : inherited from direct parent
	var integer vl_int3 := vl_gsc.vl_a;		// correct : inherited from upper parent
	
	var charstring vl_int4 := vl_gsc.vl_d;		// incorrect : nonexisting member
	var charstring vl_int5 := vl_gsc.vl_a;		// incorrect : type mismatch
157
158
159
160
161
162
163
164
165
	
	var OuterClass vl_outer := OuterClass.create;
	var OuterClass vl_outer2;
	if (vl_outer of OuterClass) {			
		vl_outer := vl_outer2;
	}
	
	var integer vl_integer := vl_outer of OuterClass;			// type mismatch
	var boolean vl_boolean := vl_outer of BaseFunctionClass;	// semanticall correct
166
167
168
}

}