OopNegativeSemanticTest.ttcn 5.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
34
35
36
37
38
39
40
type class MinimalClass { }
type class @abstract MinimalAbstractClass { }
type class @final MinimalFinalClass { }
type class @trait MinimalTraitClass { }

type class BadExtends extends MinimalClass, MinimalAbstractClass, MinimalFinalClass, MinimalTraitClass {
	// dummy
}

41
42
43
44
type class @trait BadExtends2 extends MinimalFinalClass, MinimalTraitClass {
	// dummy
}

45
46
type class SuperClass {
	var integer vl_a;
47
	template MyUnion t_union := { a := 10 }
48
}
49
 
50
type class SubClass extends SuperClass {
51
	public var integer vl_b;
52
53
54
55
}

type class GrandSubClass extends SubClass {
	var integer vl_c;
56
	template MyUnion t_union2 := { nonexist := 10 }		// non-existing template member
57
58
59
60
61
62
63
64
65
66
67
68
}

type class GrandSubClass2 extends SubClass {
	var charstring vl_b;
}

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

69
type class OuterClass {
70
	private var integer m_int := 0; 
71
72
73
74
75
76
77

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

		class InnerClass {
			private template MyUnion t_union;
			public var integer badInteger := "xyz";
78
79
80
81
82
83
84
			
			public class EvenDeeper {
				public const charstring chr := "abc";
				
				public class Core {			  
    				public function f_inside(in integer pl_int) return charstring {
    					return this.chr;
85
					}
86
87
				}
			}
88
89
90
91
		}
	}
}

92
93
94
95
96
97
98
99
100
101
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
	}
}

102
103
const integer cg_uninitConst1;

104
105
type class SubFunctionClass extends BaseFunctionClass {  
	private const integer m_const := 1;
106
	private const integer m_uninitConst2;
107
108
109
110
111
	public function f_get_one() return integer {		// FIXME : incomplete marker
		return m_const;
	}
}

112
113
114
115
// an abstract class can have a finally block
type class @abstract FinallyClass {
	public const integer m_const := 0;
} finally {
116
	log(this.m_const);
117
118
119
120
121
122
}

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

126
127
128
129
130
// bad combination of class modifiers
type class @final @abstract BadClass1 { }
type class @final @trait BadClass3 { }
type class @abstract @trait BadClass2 { }

131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
// 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;
	}
}

150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
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();
	}
169
170
171
172
173
174
175
176
177
178
	
	public function f_dummy(in integer pl_int) return float {
		return 0.1;
	}
}

// function with class parameter
function f_class_param(FuncClass pl_fun) {
	var integer vl_int := pl_fun.f_dummy(1);		// type mismatch
	var charstring vl_chr := pl_fun.f_get_one();	// correct
179
180
}

181
182
183
184
185
186
187
188
189
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
190
191
192
193
194
195
196
197
198
	
	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
199
200
201
	
	// nested class member reference
	var octetstring vl_octet := vl_outer.NestedClass.InnerClass.EvenDeeper.Core.f_inside(1)
202
203
204
}

}