Skip to content
Open
Show file tree
Hide file tree
Changes from 10 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
b77dc00
test: add tests for Axis constructor and properties
Sachinn-64 Feb 21, 2026
60c07d5
Update lib/node_modules/@stdlib/plot/vega/axis/ctor/test/test.aria.js
Sachinn-64 Mar 2, 2026
37c64cb
Update lib/node_modules/@stdlib/plot/vega/axis/ctor/test/test.band_po…
Sachinn-64 Mar 2, 2026
83e8bf9
update: revert changes
Sachinn-64 Mar 2, 2026
1a4db27
Fix formatting in axis example
Sachinn-64 Mar 2, 2026
fe9183a
update: revert changes
Sachinn-64 Mar 2, 2026
50ae1d6
chore: suggested changes
Sachinn-64 Mar 7, 2026
eed4ff0
chore: suggested changes
Sachinn-64 Mar 27, 2026
a0fe34f
style: address lint error
kgryte May 3, 2026
73640cc
test: fix grammar in descriptions
kgryte May 4, 2026
f8eeb15
Apply suggestions from code review
kgryte May 4, 2026
c4447dd
Merge branch 'refactor/plot' into test-plot-vega-axis
kgryte May 5, 2026
0c054f9
chore: suggested changes
Sachinn-64 May 5, 2026
0fdbcbe
Apply suggestions from code review
kgryte May 9, 2026
87f7a05
Apply suggestions from code review
kgryte May 9, 2026
ebaf207
Apply suggestions from code review
kgryte May 9, 2026
f1fe0c6
Apply suggestions from code review
kgryte May 9, 2026
76622dc
Merge branch 'refactor/plot' into test-plot-vega-axis
kgryte May 9, 2026
2ea5891
Apply suggestions from code review
kgryte May 9, 2026
a0b5dd6
Apply suggestions from code review
kgryte May 9, 2026
df59882
Apply suggestions from code review
kgryte May 9, 2026
89109d4
Apply suggestions from code review
kgryte May 9, 2026
bc7d2b7
Apply suggestions from code review
kgryte May 9, 2026
87098c5
Apply suggestions from code review
kgryte May 9, 2026
1135041
Apply suggestions from code review
kgryte May 9, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
151 changes: 151 additions & 0 deletions lib/node_modules/@stdlib/plot/vega/axis/ctor/test/test.aria.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
/**
* @license Apache-2.0
*
* Copyright (c) 2026 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

'use strict';

// MODULES //

var tape = require( 'tape' );
var hasOwnProp = require( '@stdlib/assert/has-own-property' );
var hasProp = require( '@stdlib/assert/has-property' );
var isBoolean = require( '@stdlib/assert/is-boolean' );
Comment thread
kgryte marked this conversation as resolved.
Outdated
var Axis = require( './../lib' );


// TESTS //
Comment thread
kgryte marked this conversation as resolved.

tape( 'main export is a function', function test( t ) {
t.ok( true, __filename );
t.strictEqual( typeof Axis, 'function', 'main export is a function' );
t.end();
});

tape( 'the constructor returns an instance which has an `aria` property', function test( t ) {
var v;

v = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
t.strictEqual( hasOwnProp( v, 'aria' ), false, 'returns expected value' );
t.strictEqual( hasProp( v, 'aria' ), true, 'returns expected value' );
t.strictEqual( isBoolean( v.aria ), true, 'returns expected value' );
t.end();
});

tape( 'the constructor returns an instance having an `aria` property which throws an error if set to a non-boolean value', function test( t ) {
var values;
var i;

values = [
'5',
5,
NaN,
null,
void 0,
[],
{},
function noop() {}
];
for ( i = 0; i < values.length; i++ ) {
t.throws( badValue( values[ i ] ), TypeError, 'throws an error when provided ' + values[ i ] );
}
t.end();

function badValue( value ) {
return function badValue() {
var axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
axis.aria = value;
};
}
});

tape( 'the constructor returns an instance having an `aria` property', function test( t ) {
var axis;

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
t.strictEqual( axis.aria, true, 'returns expected value' );

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom',
'aria': false
});
t.strictEqual( axis.aria, false, 'returns expected value' );

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom',
'aria': true
});
t.strictEqual( axis.aria, true, 'returns expected value' );

t.end();
});

tape( 'the constructor returns an instance having an `aria` property which can be set to a boolean', function test( t ) {
var axis;

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});

axis.aria = true;
t.strictEqual( axis.aria, true, 'returns expected value' );

axis.aria = false;
t.strictEqual( axis.aria, false, 'returns expected value' );

t.end();
});

tape( 'the constructor returns an instance which emits an event when the `aria` property is set to a new value', function test( t ) {
var count;
var axis;

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
count = 0;

axis.on( 'change', onChange );

axis.aria = false;
t.strictEqual( count, 1, 'returns expected value' );

axis.aria = true;
t.strictEqual( count, 2, 'returns expected value' );

// Setting to the same value should not emit an event:
axis.aria = true;
t.strictEqual( count, 2, 'returns expected value' );

t.end();

function onChange() {
count += 1;
}
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
/**
* @license Apache-2.0
*
* Copyright (c) 2026 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

'use strict';

// MODULES //

var tape = require( 'tape' );
var hasOwnProp = require( '@stdlib/assert/has-own-property' );
var isUndefined = require( '@stdlib/assert/is-undefined' );
var hasProp = require( '@stdlib/assert/has-property' );
var isNumber = require( '@stdlib/assert/is-number' ).isPrimitive;
var Axis = require( './../lib' );

// TESTS //

Check failure on line 30 in lib/node_modules/@stdlib/plot/vega/axis/ctor/test/test.band_position.js

View workflow job for this annotation

GitHub Actions / Lint Changed Files

Header comment must be preceded by one additional empty line
Comment thread
kgryte marked this conversation as resolved.

tape( 'main export is a function', function test( t ) {
t.ok( true, __filename );
t.strictEqual( typeof Axis, 'function', 'main export is a function' );
t.end();
});

tape( 'the constructor returns an instance which has a `bandPosition` property', function test( t ) {
var v;

v = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
t.strictEqual( hasOwnProp( v, 'bandPosition' ), false, 'returns expected value' );
t.strictEqual( hasProp( v, 'bandPosition' ), true, 'returns expected value' );
t.strictEqual( isUndefined( v.bandPosition ), true, 'returns expected value' );

v = new Axis({
'scale': 'xScale',
'orient': 'bottom',
'bandPosition': 0.5
});
t.strictEqual( isNumber( v.bandPosition ), true, 'returns expected value' );

t.end();
});

tape( 'the constructor returns an instance having a `bandPosition` property which throws an error if set to an invalid value', function test( t ) {
var values;
var i;

values = [
'beep',
-0.1,
1.1,
NaN,
{},
function noop() {}
];
for ( i = 0; i < values.length; i++ ) {
t.throws( badValue( values[ i ] ), TypeError, 'throws an error when provided ' + values[ i ] );
}
t.end();

function badValue( value ) {
return function badValue() {
var axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
axis.bandPosition = value;
};
}
});

tape( 'the constructor returns an instance having a `bandPosition` property', function test( t ) {
var axis;

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
t.strictEqual( isUndefined( axis.bandPosition ), true, 'returns expected value' );

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom',
'bandPosition': 0.5
});
t.strictEqual( axis.bandPosition, 0.5, 'returns expected value' );

t.end();
});

tape( 'the constructor returns an instance having a `bandPosition` property which can be set to a valid value', function test( t ) {
var axis;

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});

axis.bandPosition = 0.5;
t.strictEqual( axis.bandPosition, 0.5, 'returns expected value' );

axis.bandPosition = 0;
t.strictEqual( axis.bandPosition, 0, 'returns expected value' );

axis.bandPosition = 1;
t.strictEqual( axis.bandPosition, 1, 'returns expected value' );

t.end();
});

tape( 'the constructor returns an instance which emits an event when the `bandPosition` property is set to a new value', function test( t ) {

Check failure on line 126 in lib/node_modules/@stdlib/plot/vega/axis/ctor/test/test.band_position.js

View workflow job for this annotation

GitHub Actions / Lint Changed Files

Variable declarations inside of function are not ordered by length (in decreasing order)
var axis;
var count;
Comment thread
kgryte marked this conversation as resolved.
Outdated

axis = new Axis({
'scale': 'xScale',
'orient': 'bottom'
});
count = 0;

axis.on( 'change', onChange );

axis.bandPosition = 0.5;
t.strictEqual( count, 1, 'returns expected value' );

axis.bandPosition = 0.3;
t.strictEqual( count, 2, 'returns expected value' );

// Setting to the same value should not emit an event:
axis.bandPosition = 0.3;
t.strictEqual( count, 2, 'returns expected value' );

t.end();

function onChange() {
count += 1;
}
});
Loading
Loading