v8/tools/clusterfuzz/js_fuzzer/test/test_random.js
Michael Achenbach 320d98709f Open source js-fuzzer
This is a JavaScript fuzzer originally authored by Oliver Chang. It
is a mutation based fuzzer using Babel code transformations. For more
information see the included README.md.

The original code was altered:
- Add new V8 copyright headers.
- Make the test expectation generator aware of the headers.
- Fix file endings for presubmit checks.
- Fix `npm test` on fresh checkout with a new fake DB.
- Make test skipping work with new v8/tools location.
- OWNERS file.
- New title section in README.md.

No-Try: true
Bug: chromium:1109770
Change-Id: Ie71752c0a37491a50500c49060a3c526716ef933
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2320330
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Maya Lekova <mslekova@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69164}
2020-07-31 11:34:39 +00:00

52 lines
1.6 KiB
JavaScript

// Copyright 2020 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
/**
* @fileoverview Test random utilities.
*/
'use strict';
const assert = require('assert');
const sinon = require('sinon');
const { twoBucketSample } = require('../random.js');
const sandbox = sinon.createSandbox();
describe('Two-bucket choosing', () => {
afterEach(() => {
sandbox.restore();
});
it('with one empty', () => {
sandbox.stub(Math, 'random').callsFake(() => 0.5);
assert.deepEqual([1, 2], twoBucketSample([0, 1, 2], [], 1, 2));
assert.deepEqual([1, 2], twoBucketSample([], [0, 1, 2], 1, 2));
assert.deepEqual([0], twoBucketSample([0], [], 1, 1));
assert.deepEqual([0], twoBucketSample([], [0], 1, 1));
});
it('chooses with 0.3', () => {
sandbox.stub(Math, 'random').callsFake(() => 0.3);
assert.deepEqual([1, 2], twoBucketSample([0, 1, 2], [3, 4, 5], 1, 2));
// Higher factor.
assert.deepEqual([3, 5], twoBucketSample([0, 1, 2], [3, 4, 5], 4, 2));
});
it('chooses with 0.7', () => {
sandbox.stub(Math, 'random').callsFake(() => 0.7);
assert.deepEqual([4, 3], twoBucketSample([0, 1, 2], [3, 4, 5], 1, 2));
});
it('chooses with 0.5', () => {
sandbox.stub(Math, 'random').callsFake(() => 0.5);
assert.deepEqual([3], twoBucketSample([0, 1], [2, 3, 4, 5], 1, 1));
assert.deepEqual([3], twoBucketSample([0, 1, 2, 3], [4, 5], 1, 1));
// Higher factor.
assert.deepEqual([4], twoBucketSample([0, 1, 2, 3], [4, 5], 2, 1));
});
});