Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(279)

Side by Side Diff: tests/compiler/dart2js/private_test.dart

Issue 15781008: Warn on private members. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fix bug and add regression. Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « sdk/lib/_internal/compiler/implementation/warnings.dart ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file.
4
5 import "package:expect/expect.dart";
6 import 'mock_compiler.dart';
7
8 import '../../../sdk/lib/_internal/compiler/implementation/source_file.dart';
9 import '../../../sdk/lib/_internal/compiler/implementation/dart2jslib.dart'
10 hide SourceString;
11
12 const String PRIVATE_SOURCE_URI = 'src:private';
13 const String PRIVATE_SOURCE = '''
14
15 var _privateVariable;
16 void _privateFunction() {}
17
18 class _PrivateClass {
19 _PrivateClass();
20 _PrivateClass.publicConstructor();
21 _PrivateClass._privateConstructor();
22
23 var _privateField;
24 get _privateGetter => null;
25 void set _privateSetter(var value) {}
26 void _privateMethod() {}
27
28 var publicField;
29 get publicGetter => null;
30 void set publicSetter(var value) {}
31 void publicMethod() {}
32 }
33
34 class PublicClass extends _PrivateClass {
35 PublicClass() : super();
36 PublicClass.publicConstructor() : super.publicConstructor();
37 PublicClass._privateConstructor() : super._privateConstructor();
38
39 _PrivateClass get private => this;
40 }
41 ''';
42
43
44 void analyze(String text, [expectedWarnings]) {
45 if (expectedWarnings == null) expectedWarnings = [];
46 if (expectedWarnings is !List) expectedWarnings = [expectedWarnings];
47
48 MockCompiler compiler = new MockCompiler(analyzeOnly: true);
49 compiler.registerSource(Uri.parse(PRIVATE_SOURCE_URI), PRIVATE_SOURCE);
50 compiler.diagnosticHandler = (uri, int begin, int end, String message, kind) {
51 SourceFile sourceFile = compiler.sourceFiles[uri.toString()];
52 if (sourceFile != null) {
53 print(sourceFile.getLocationMessage(message, begin, end, true, (x) => x));
54 } else {
55 print(message);
56 }
57 };
58
59 String source = '''
60 library public;
61
62 import '$PRIVATE_SOURCE_URI';
63
64 void main() {
65 PublicClass publicClass;
66 $text
67 }
68 ''';
69 Uri uri = Uri.parse('src:public');
70 compiler.registerSource(uri, source);
71 compiler.runCompiler(uri);
72 compareWarningKinds(text, expectedWarnings, compiler.warnings);
73 }
74
75 void main() {
76 // Read from private variable.
77 analyze('var value = _privateVariable;', MessageKind.CANNOT_RESOLVE);
78 // Write to private variable.
79 analyze('_privateVariable = 0;', MessageKind.CANNOT_RESOLVE);
80 // Access private function.
81 analyze('var value = _privateFunction;', MessageKind.CANNOT_RESOLVE);
82 // Call private function.
83 analyze('_privateFunction();', MessageKind.CANNOT_RESOLVE);
84
85 // Call unnamed (public) constructor on private class.
86 analyze('new _PrivateClass();', MessageKind.CANNOT_RESOLVE);
87 // Call public constructor on private class.
88 analyze('new _PrivateClass.publicConstructor();', MessageKind.CANNOT_RESOLVE);
89 // Call private constructor on private class.
90 analyze('new _PrivateClass._privateConstructor();',
91 MessageKind.CANNOT_RESOLVE);
92 // Call public getter of private type.
93 analyze('var value = publicClass.private;');
94 // Read from private field on private class.
95 analyze('var value = publicClass.private._privateField;',
96 MessageKind.PRIVATE_ACCESS);
97 // Write to private field on private class.
98 analyze('publicClass.private._privateField = 0;',
99 MessageKind.PRIVATE_ACCESS);
100 // Call private getter on private class.
101 analyze('var value = publicClass.private._privateGetter;',
102 MessageKind.PRIVATE_ACCESS);
103 // Call private setter on private class.
104 analyze('publicClass.private._privateSetter = 0;',
105 MessageKind.PRIVATE_ACCESS);
106 // Access private method on private class.
107 analyze('var value = publicClass.private._privateMethod;',
108 MessageKind.PRIVATE_ACCESS);
109 // Call private method on private class.
110 analyze('publicClass.private._privateMethod();',
111 MessageKind.PRIVATE_ACCESS);
112
113 // Read from public field on private class.
114 analyze('var value = publicClass.private.publicField;');
115 // Write to public field on private class.
116 analyze('publicClass.private.publicField = 0;');
117 // Call public getter on private class.
118 analyze('var value = publicClass.private.publicGetter;');
119 // Call public setter on private class.
120 analyze('publicClass.private.publicSetter = 0;');
121 // Access public method on private class.
122 analyze('var value = publicClass.private.publicMethod;');
123 // Call public method on private class.
124 analyze('publicClass.private.publicMethod();');
125
126 // Call unnamed (public) constructor on public class.
127 analyze('publicClass = new PublicClass();');
128 // Call public constructor on public class.
129 analyze('publicClass = new PublicClass.publicConstructor();');
130 // Call private constructor on public class.
131 analyze('publicClass = new PublicClass._privateConstructor();',
132 MessageKind.CANNOT_FIND_CONSTRUCTOR);
133 // Read from private field on public class.
134 analyze('var value = publicClass._privateField;',
135 MessageKind.PRIVATE_ACCESS);
136 // Write to private field on public class.
137 analyze('publicClass._privateField = 0;',
138 MessageKind.PRIVATE_ACCESS);
139 // Call private getter on public class.
140 analyze('var value = publicClass._privateGetter;',
141 MessageKind.PRIVATE_ACCESS);
142 // Call private setter on public class.
143 analyze('publicClass._privateSetter = 0;',
144 MessageKind.PRIVATE_ACCESS);
145 // Access private method on public class.
146 analyze('var value = publicClass._privateMethod;',
147 MessageKind.PRIVATE_ACCESS);
148 // Call private method on public class.
149 analyze('publicClass._privateMethod();',
150 MessageKind.PRIVATE_ACCESS);
151
152 // Read from public field on public class.
153 analyze('var value = publicClass.publicField;');
154 // Write to public field on public class.
155 analyze('publicClass.publicField = 0;');
156 // Call public getter on public class.
157 analyze('var value = publicClass.publicGetter;');
158 // Call public setter on public class.
159 analyze('publicClass.publicSetter = 0;');
160 // Access public method on public class.
161 analyze('var value = publicClass.publicMethod;');
162 // Call public method on public class.
163 analyze('publicClass.publicMethod();');
164 }
165
OLDNEW
« no previous file with comments | « sdk/lib/_internal/compiler/implementation/warnings.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698