1 | /**
|
2 | * @license
|
3 | * Copyright 2019 Google LLC. All Rights Reserved.
|
4 | * Licensed under the Apache License, Version 2.0 (the "License");
|
5 | * you may not use this file except in compliance with the License.
|
6 | * You may obtain a copy of the License at
|
7 | *
|
8 | * http://www.apache.org/licenses/LICENSE-2.0
|
9 | *
|
10 | * Unless required by applicable law or agreed to in writing, software
|
11 | * distributed under the License is distributed on an "AS IS" BASIS,
|
12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13 | * See the License for the specific language governing permissions and
|
14 | * limitations under the License.
|
15 | * =============================================================================
|
16 | */
|
17 | import * as tf from './index';
|
18 | import { ALL_ENVS, describeWithFlags, NODE_ENVS } from './jasmine_util';
|
19 | import { expectArraysClose } from './test_util';
|
20 | describe('deprecation warnings', () => {
|
21 | beforeEach(() => {
|
22 | spyOn(console, 'warn').and.callFake((msg) => null);
|
23 | });
|
24 | it('deprecationWarn warns', () => {
|
25 | // flags_test.ts verifies deprecation warnings are on by default.
|
26 | const deprecationVal = tf.env().get('DEPRECATION_WARNINGS_ENABLED');
|
27 | tf.env().set('DEPRECATION_WARNINGS_ENABLED', true);
|
28 | tf.deprecationWarn('xyz is deprecated.');
|
29 | tf.env().set('DEPRECATION_WARNINGS_ENABLED', deprecationVal);
|
30 | expect(console.warn).toHaveBeenCalledTimes(1);
|
31 | expect(console.warn)
|
32 | .toHaveBeenCalledWith('xyz is deprecated. You can disable deprecation warnings with ' +
|
33 | 'tf.disableDeprecationWarnings().');
|
34 | });
|
35 | it('disableDeprecationWarnings called, deprecationWarn doesnt warn', () => {
|
36 | tf.disableDeprecationWarnings();
|
37 | expect(console.warn).toHaveBeenCalledTimes(1);
|
38 | expect(console.warn)
|
39 | .toHaveBeenCalledWith('TensorFlow.js deprecation warnings have been disabled.');
|
40 | // deprecationWarn no longer warns.
|
41 | tf.deprecationWarn('xyz is deprecated.');
|
42 | expect(console.warn).toHaveBeenCalledTimes(1);
|
43 | });
|
44 | });
|
45 | describe('Flag flipping methods', () => {
|
46 | beforeEach(() => {
|
47 | tf.env().reset();
|
48 | });
|
49 | afterEach(() => {
|
50 | tf.env().reset();
|
51 | });
|
52 | it('tf.enableProdMode', () => {
|
53 | tf.enableProdMode();
|
54 | expect(tf.env().getBool('PROD')).toBe(true);
|
55 | });
|
56 | it('tf.enableDebugMode', () => {
|
57 | // Silence debug warnings.
|
58 | spyOn(console, 'warn');
|
59 | tf.enableDebugMode();
|
60 | expect(tf.env().getBool('DEBUG')).toBe(true);
|
61 | });
|
62 | });
|
63 | describeWithFlags('time cpu', NODE_ENVS, () => {
|
64 | it('simple upload', async () => {
|
65 | const a = tf.zeros([10, 10]);
|
66 | const time = await tf.time(() => a.square());
|
67 | expect(time.kernelMs > 0);
|
68 | expect(time.wallMs >= time.kernelMs);
|
69 | });
|
70 | });
|
71 | describeWithFlags('tidy', ALL_ENVS, () => {
|
72 | it('returns Tensor', async () => {
|
73 | tf.tidy(() => {
|
74 | const a = tf.tensor1d([1, 2, 3]);
|
75 | let b = tf.tensor1d([0, 0, 0]);
|
76 | expect(tf.memory().numTensors).toBe(2);
|
77 | tf.tidy(() => {
|
78 | const result = tf.tidy(() => {
|
79 | b = tf.add(a, b);
|
80 | b = tf.add(a, b);
|
81 | b = tf.add(a, b);
|
82 | return tf.add(a, b);
|
83 | });
|
84 | // result is new. All intermediates should be disposed.
|
85 | expect(tf.memory().numTensors).toBe(2 + 1);
|
86 | expect(result.shape).toEqual([3]);
|
87 | expect(result.isDisposed).toBe(false);
|
88 | });
|
89 | // a, b are still here, result should be disposed.
|
90 | expect(tf.memory().numTensors).toBe(2);
|
91 | });
|
92 | expect(tf.memory().numTensors).toBe(0);
|
93 | });
|
94 | it('multiple disposes does not affect num arrays', () => {
|
95 | expect(tf.memory().numTensors).toBe(0);
|
96 | const a = tf.tensor1d([1, 2, 3]);
|
97 | const b = tf.tensor1d([1, 2, 3]);
|
98 | expect(tf.memory().numTensors).toBe(2);
|
99 | a.dispose();
|
100 | a.dispose();
|
101 | expect(tf.memory().numTensors).toBe(1);
|
102 | b.dispose();
|
103 | expect(tf.memory().numTensors).toBe(0);
|
104 | });
|
105 | it('allows primitive types', () => {
|
106 | const a = tf.tidy(() => 5);
|
107 | expect(a).toBe(5);
|
108 | const b = tf.tidy(() => 'hello');
|
109 | expect(b).toBe('hello');
|
110 | });
|
111 | it('allows complex types', async () => {
|
112 | const res = tf.tidy(() => {
|
113 | return { a: tf.scalar(1), b: 'hello', c: [tf.scalar(2), 'world'] };
|
114 | });
|
115 | expectArraysClose(await res.a.data(), [1]);
|
116 | expectArraysClose(await res.c[0].data(), [2]);
|
117 | });
|
118 | it('returns Tensor[]', async () => {
|
119 | const a = tf.tensor1d([1, 2, 3]);
|
120 | const b = tf.tensor1d([0, -1, 1]);
|
121 | expect(tf.memory().numTensors).toBe(2);
|
122 | tf.tidy(() => {
|
123 | const result = tf.tidy(() => {
|
124 | tf.add(a, b);
|
125 | return [tf.add(a, b), tf.sub(a, b)];
|
126 | });
|
127 | // the 2 results are new. All intermediates should be disposed.
|
128 | expect(tf.memory().numTensors).toBe(4);
|
129 | expect(result[0].isDisposed).toBe(false);
|
130 | expect(result[0].shape).toEqual([3]);
|
131 | expect(result[1].isDisposed).toBe(false);
|
132 | expect(result[1].shape).toEqual([3]);
|
133 | expect(tf.memory().numTensors).toBe(4);
|
134 | });
|
135 | // the 2 results should be disposed.
|
136 | expect(tf.memory().numTensors).toBe(2);
|
137 | a.dispose();
|
138 | b.dispose();
|
139 | expect(tf.memory().numTensors).toBe(0);
|
140 | });
|
141 | it('basic usage without return', () => {
|
142 | const a = tf.tensor1d([1, 2, 3]);
|
143 | let b = tf.tensor1d([0, 0, 0]);
|
144 | expect(tf.memory().numTensors).toBe(2);
|
145 | tf.tidy(() => {
|
146 | b = tf.add(a, b);
|
147 | b = tf.add(a, b);
|
148 | b = tf.add(a, b);
|
149 | tf.add(a, b);
|
150 | });
|
151 | // all intermediates should be disposed.
|
152 | expect(tf.memory().numTensors).toBe(2);
|
153 | });
|
154 | it('nested usage', async () => {
|
155 | const a = tf.tensor1d([1, 2, 3]);
|
156 | let b = tf.tensor1d([0, 0, 0]);
|
157 | expect(tf.memory().numTensors).toBe(2);
|
158 | tf.tidy(() => {
|
159 | const result = tf.tidy(() => {
|
160 | b = tf.add(a, b);
|
161 | b = tf.tidy(() => {
|
162 | b = tf.tidy(() => {
|
163 | return tf.add(a, b);
|
164 | });
|
165 | // original a, b, and two intermediates.
|
166 | expect(tf.memory().numTensors).toBe(4);
|
167 | tf.tidy(() => {
|
168 | tf.add(a, b);
|
169 | });
|
170 | // All the intermediates should be cleaned up.
|
171 | expect(tf.memory().numTensors).toBe(4);
|
172 | return tf.add(a, b);
|
173 | });
|
174 | expect(tf.memory().numTensors).toBe(4);
|
175 | return tf.add(a, b);
|
176 | });
|
177 | expect(tf.memory().numTensors).toBe(3);
|
178 | expect(result.isDisposed).toBe(false);
|
179 | expect(result.shape).toEqual([3]);
|
180 | });
|
181 | expect(tf.memory().numTensors).toBe(2);
|
182 | });
|
183 | it('nested usage returns tensor created from outside scope', () => {
|
184 | const x = tf.scalar(1);
|
185 | tf.tidy(() => {
|
186 | tf.tidy(() => {
|
187 | return x;
|
188 | });
|
189 | });
|
190 | expect(x.isDisposed).toBe(false);
|
191 | });
|
192 | it('nested usage with keep works', () => {
|
193 | let b;
|
194 | tf.tidy(() => {
|
195 | const a = tf.scalar(1);
|
196 | tf.tidy(() => {
|
197 | b = tf.keep(a);
|
198 | });
|
199 | });
|
200 | expect(b.isDisposed).toBe(false);
|
201 | b.dispose();
|
202 | });
|
203 | it('single argument', () => {
|
204 | let hasRan = false;
|
205 | tf.tidy(() => {
|
206 | hasRan = true;
|
207 | });
|
208 | expect(hasRan).toBe(true);
|
209 | });
|
210 | it('single argument, but not a function throws error', () => {
|
211 | expect(() => {
|
212 | tf.tidy('asdf');
|
213 | }).toThrowError();
|
214 | });
|
215 | it('2 arguments, first is string', () => {
|
216 | let hasRan = false;
|
217 | tf.tidy('name', () => {
|
218 | hasRan = true;
|
219 | });
|
220 | expect(hasRan).toBe(true);
|
221 | });
|
222 | it('2 arguments, but first is not string throws error', () => {
|
223 | expect(() => {
|
224 | // tslint:disable-next-line:no-any
|
225 | tf.tidy(4, () => { });
|
226 | }).toThrowError();
|
227 | });
|
228 | it('2 arguments, but second is not a function throws error', () => {
|
229 | expect(() => {
|
230 | // tslint:disable-next-line:no-any
|
231 | tf.tidy('name', 'another name');
|
232 | }).toThrowError();
|
233 | });
|
234 | it('works with arbitrary depth of result', async () => {
|
235 | tf.tidy(() => {
|
236 | const res = tf.tidy(() => {
|
237 | return [tf.scalar(1), [[tf.scalar(2)]], { list: [tf.scalar(3)] }];
|
238 | });
|
239 | expect(res[0].isDisposed).toBe(false);
|
240 | // tslint:disable-next-line:no-any
|
241 | expect(res[1][0][0].isDisposed).toBe(false);
|
242 | // tslint:disable-next-line:no-any
|
243 | expect(res[2].list[0].isDisposed).toBe(false);
|
244 | expect(tf.memory().numTensors).toBe(3);
|
245 | return res[0];
|
246 | });
|
247 | // Everything but scalar(1) got disposed.
|
248 | expect(tf.memory().numTensors).toBe(1);
|
249 | });
|
250 | });
|
251 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"globals_test.js","sourceRoot":"","sources":["../../../../../tfjs-core/src/globals_test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as tf from './index';\nimport {ALL_ENVS, describeWithFlags, NODE_ENVS} from './jasmine_util';\nimport {expectArraysClose} from './test_util';\n\ndescribe('deprecation warnings', () => {\n  beforeEach(() => {\n    spyOn(console, 'warn').and.callFake((msg: string): void => null);\n  });\n\n  it('deprecationWarn warns', () => {\n    // flags_test.ts verifies deprecation warnings are on by default.\n    const deprecationVal = tf.env().get('DEPRECATION_WARNINGS_ENABLED');\n    tf.env().set('DEPRECATION_WARNINGS_ENABLED', true);\n    tf.deprecationWarn('xyz is deprecated.');\n    tf.env().set('DEPRECATION_WARNINGS_ENABLED', deprecationVal);\n    expect(console.warn).toHaveBeenCalledTimes(1);\n    expect(console.warn)\n        .toHaveBeenCalledWith(\n            'xyz is deprecated. You can disable deprecation warnings with ' +\n            'tf.disableDeprecationWarnings().');\n  });\n\n  it('disableDeprecationWarnings called, deprecationWarn doesnt warn', () => {\n    tf.disableDeprecationWarnings();\n    expect(console.warn).toHaveBeenCalledTimes(1);\n    expect(console.warn)\n        .toHaveBeenCalledWith(\n            'TensorFlow.js deprecation warnings have been disabled.');\n\n    // deprecationWarn no longer warns.\n    tf.deprecationWarn('xyz is deprecated.');\n    expect(console.warn).toHaveBeenCalledTimes(1);\n  });\n});\n\ndescribe('Flag flipping methods', () => {\n  beforeEach(() => {\n    tf.env().reset();\n  });\n\n  afterEach(() => {\n    tf.env().reset();\n  });\n\n  it('tf.enableProdMode', () => {\n    tf.enableProdMode();\n    expect(tf.env().getBool('PROD')).toBe(true);\n  });\n\n  it('tf.enableDebugMode', () => {\n    // Silence debug warnings.\n    spyOn(console, 'warn');\n    tf.enableDebugMode();\n    expect(tf.env().getBool('DEBUG')).toBe(true);\n  });\n});\n\ndescribeWithFlags('time cpu', NODE_ENVS, () => {\n  it('simple upload', async () => {\n    const a = tf.zeros([10, 10]);\n    const time = await tf.time(() => a.square());\n    expect(time.kernelMs > 0);\n    expect(time.wallMs >= time.kernelMs);\n  });\n});\n\ndescribeWithFlags('tidy', ALL_ENVS, () => {\n  it('returns Tensor', async () => {\n    tf.tidy(() => {\n      const a = tf.tensor1d([1, 2, 3]);\n      let b = tf.tensor1d([0, 0, 0]);\n\n      expect(tf.memory().numTensors).toBe(2);\n      tf.tidy(() => {\n        const result = tf.tidy(() => {\n          b = tf.add(a, b);\n          b = tf.add(a, b);\n          b = tf.add(a, b);\n          return tf.add(a, b);\n        });\n\n        // result is new. All intermediates should be disposed.\n        expect(tf.memory().numTensors).toBe(2 + 1);\n        expect(result.shape).toEqual([3]);\n        expect(result.isDisposed).toBe(false);\n      });\n\n      // a, b are still here, result should be disposed.\n      expect(tf.memory().numTensors).toBe(2);\n    });\n\n    expect(tf.memory().numTensors).toBe(0);\n  });\n\n  it('multiple disposes does not affect num arrays', () => {\n    expect(tf.memory().numTensors).toBe(0);\n    const a = tf.tensor1d([1, 2, 3]);\n    const b = tf.tensor1d([1, 2, 3]);\n    expect(tf.memory().numTensors).toBe(2);\n    a.dispose();\n    a.dispose();\n    expect(tf.memory().numTensors).toBe(1);\n    b.dispose();\n    expect(tf.memory().numTensors).toBe(0);\n  });\n\n  it('allows primitive types', () => {\n    const a = tf.tidy(() => 5);\n    expect(a).toBe(5);\n\n    const b = tf.tidy(() => 'hello');\n    expect(b).toBe('hello');\n  });\n\n  it('allows complex types', async () => {\n    const res = tf.tidy(() => {\n      return {a: tf.scalar(1), b: 'hello', c: [tf.scalar(2), 'world']};\n    });\n    expectArraysClose(await res.a.data(), [1]);\n    expectArraysClose(await (res.c[0] as tf.Tensor).data(), [2]);\n  });\n\n  it('returns Tensor[]', async () => {\n    const a = tf.tensor1d([1, 2, 3]);\n    const b = tf.tensor1d([0, -1, 1]);\n    expect(tf.memory().numTensors).toBe(2);\n\n    tf.tidy(() => {\n      const result = tf.tidy(() => {\n        tf.add(a, b);\n        return [tf.add(a, b), tf.sub(a, b)];\n      });\n\n      // the 2 results are new. All intermediates should be disposed.\n      expect(tf.memory().numTensors).toBe(4);\n      expect(result[0].isDisposed).toBe(false);\n      expect(result[0].shape).toEqual([3]);\n      expect(result[1].isDisposed).toBe(false);\n      expect(result[1].shape).toEqual([3]);\n      expect(tf.memory().numTensors).toBe(4);\n    });\n\n    // the 2 results should be disposed.\n    expect(tf.memory().numTensors).toBe(2);\n    a.dispose();\n    b.dispose();\n    expect(tf.memory().numTensors).toBe(0);\n  });\n\n  it('basic usage without return', () => {\n    const a = tf.tensor1d([1, 2, 3]);\n    let b = tf.tensor1d([0, 0, 0]);\n\n    expect(tf.memory().numTensors).toBe(2);\n\n    tf.tidy(() => {\n      b = tf.add(a, b);\n      b = tf.add(a, b);\n      b = tf.add(a, b);\n      tf.add(a, b);\n    });\n\n    // all intermediates should be disposed.\n    expect(tf.memory().numTensors).toBe(2);\n  });\n\n  it('nested usage', async () => {\n    const a = tf.tensor1d([1, 2, 3]);\n    let b = tf.tensor1d([0, 0, 0]);\n\n    expect(tf.memory().numTensors).toBe(2);\n\n    tf.tidy(() => {\n      const result = tf.tidy(() => {\n        b = tf.add(a, b);\n        b = tf.tidy(() => {\n          b = tf.tidy(() => {\n            return tf.add(a, b);\n          });\n          // original a, b, and two intermediates.\n          expect(tf.memory().numTensors).toBe(4);\n\n          tf.tidy(() => {\n            tf.add(a, b);\n          });\n          // All the intermediates should be cleaned up.\n          expect(tf.memory().numTensors).toBe(4);\n\n          return tf.add(a, b);\n        });\n        expect(tf.memory().numTensors).toBe(4);\n\n        return tf.add(a, b);\n      });\n\n      expect(tf.memory().numTensors).toBe(3);\n      expect(result.isDisposed).toBe(false);\n      expect(result.shape).toEqual([3]);\n    });\n    expect(tf.memory().numTensors).toBe(2);\n  });\n\n  it('nested usage returns tensor created from outside scope', () => {\n    const x = tf.scalar(1);\n\n    tf.tidy(() => {\n      tf.tidy(() => {\n        return x;\n      });\n    });\n\n    expect(x.isDisposed).toBe(false);\n  });\n\n  it('nested usage with keep works', () => {\n    let b: tf.Tensor;\n    tf.tidy(() => {\n      const a = tf.scalar(1);\n      tf.tidy(() => {\n        b = tf.keep(a);\n      });\n    });\n\n    expect(b.isDisposed).toBe(false);\n    b.dispose();\n  });\n\n  it('single argument', () => {\n    let hasRan = false;\n    tf.tidy(() => {\n      hasRan = true;\n    });\n    expect(hasRan).toBe(true);\n  });\n\n  it('single argument, but not a function throws error', () => {\n    expect(() => {\n      tf.tidy('asdf');\n    }).toThrowError();\n  });\n\n  it('2 arguments, first is string', () => {\n    let hasRan = false;\n    tf.tidy('name', () => {\n      hasRan = true;\n    });\n    expect(hasRan).toBe(true);\n  });\n\n  it('2 arguments, but first is not string throws error', () => {\n    expect(() => {\n      // tslint:disable-next-line:no-any\n      tf.tidy(4 as any, () => {});\n    }).toThrowError();\n  });\n\n  it('2 arguments, but second is not a function throws error', () => {\n    expect(() => {\n      // tslint:disable-next-line:no-any\n      tf.tidy('name', 'another name' as any);\n    }).toThrowError();\n  });\n\n  it('works with arbitrary depth of result', async () => {\n    tf.tidy(() => {\n      const res = tf.tidy(() => {\n        return [tf.scalar(1), [[tf.scalar(2)]], {list: [tf.scalar(3)]}];\n      });\n      expect((res[0] as tf.Tensor).isDisposed).toBe(false);\n      // tslint:disable-next-line:no-any\n      expect((res[1] as any)[0][0].isDisposed).toBe(false);\n      // tslint:disable-next-line:no-any\n      expect((res[2] as any).list[0].isDisposed).toBe(false);\n      expect(tf.memory().numTensors).toBe(3);\n      return res[0];\n    });\n    // Everything but scalar(1) got disposed.\n    expect(tf.memory().numTensors).toBe(1);\n  });\n});\n"]} |
\ | No newline at end of file |