Skip to content

Commit

Permalink
Merge pull request #472 from akmorrow13/fix-variant-track
Browse files Browse the repository at this point in the history
Fix for VariantTrack failing to parse strings as ints
  • Loading branch information
akmorrow13 authored Oct 2, 2017
2 parents 78e2171 + 166185e commit 7897b19
Show file tree
Hide file tree
Showing 7 changed files with 71 additions and 8 deletions.
8 changes: 4 additions & 4 deletions src/main/data/feature.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ class Feature {
this.id = feature.id;
this.featureType = feature.featureType;
this.contig = feature.contig;
this.start = feature.start;
this.stop = feature.stop;
this.start = parseInt(feature.start);
this.stop = parseInt(feature.stop);
this.score = feature.score;
}

Expand All @@ -29,8 +29,8 @@ class Feature {
id: ga4ghFeature.id,
featureType: ga4ghFeature.featureType,
contig: ga4ghFeature.referenceName,
start: ga4ghFeature.start,
stop: ga4ghFeature.end,
start: parseInt(ga4ghFeature.start),
stop: parseInt(ga4ghFeature.end),
score: 1000
});
}
Expand Down
4 changes: 2 additions & 2 deletions src/main/data/variant.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class Variant {

constructor(variant: Object) {
this.contig = variant.contig;
this.position = variant.position;
this.position = parseInt(variant.position);
this.ref = variant.ref;
this.alt = variant.alt;
this.id = variant.id;
Expand All @@ -36,7 +36,7 @@ class Variant {
return new Variant(
{
contig: ga4ghVariant.referenceName,
position: ga4ghVariant.start,
position: parseInt(ga4ghVariant.start),
id: ga4ghVariant.id,
ref: ga4ghVariant.referenceBases,
alt: ga4ghVariant.alternateBases,
Expand Down
2 changes: 1 addition & 1 deletion src/main/json/GA4GHVariantJson.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ function create(json: string): VcfDataSource {

// fill variants with json
if (!_.isEmpty(parsedJson)) {
variants = _.values(parsedJson.variants).map(feature => Variant.fromGA4GH(feature));
variants = _.values(parsedJson.variants).map(variant => Variant.fromGA4GH(variant));
}

function rangeChanged(newRange: GenomeRange) {
Expand Down
32 changes: 32 additions & 0 deletions src/test/data/feature-test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
/* @flow */
'use strict';

import {expect} from 'chai';
import Feature from '../../main/data/feature';
import _ from 'underscore';
import RemoteFile from '../../main/RemoteFile';

describe('Feature', function() {
var json;

before(function () {
return new RemoteFile('/test-data/features.ga4gh.chr1.120000-125000.json').getAllString().then(data => {
json = data;
});
});

it('should parse features from GA4GH', function(done) {

// parse json
var parsedJson = JSON.parse(json);
var features = _.values(parsedJson.features).map(feature => Feature.fromGA4GH(feature));

expect(features).to.have.length(9);
expect(features[0].contig).to.equal("chr1");
expect(features[0].start).to.equal(89295);
expect(features[0].stop).to.equal(120932);
expect(features[0].id).to.equal("WyIxa2dlbm9tZXMiLCJnZW5jb2RlX3YyNGxpZnQzNyIsIjE0MDUwOTE3MjM1NDE5MiJd");
expect(features[0].score).to.equal(1000);
done();
});
});
31 changes: 31 additions & 0 deletions src/test/data/variant-test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/* @flow */
'use strict';

import {expect} from 'chai';
import {Variant} from '../../main/data/variant';
import _ from 'underscore';
import RemoteFile from '../../main/RemoteFile';

describe('Variant', function() {
var json;

before(function () {
return new RemoteFile('/test-data/variants.ga4gh.chr1.10000-11000.json').getAllString().then(data => {
json = data;
});
});

it('should parse variants from GA4GH', function(done) {

// parse json
var parsedJson = JSON.parse(json);
var variants = _.values(parsedJson.variants).map(variant => Variant.fromGA4GH(variant));

expect(variants).to.have.length(11);
expect(variants[0].contig).to.equal("1");
expect(variants[0].position).to.equal(10176);
expect(variants[0].ref).to.equal("A");
expect(variants[0].alt[0]).to.equal("AC");
done();
});
});
2 changes: 1 addition & 1 deletion src/test/viz/FeatureTrack-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ describe('FeatureTrack', function() {

expect(features).to.have.length(4);
expect(features.map(f => f.start)).to.deep.equal(
["89295", "92230", "110953", "120725"]);
[89295, 92230, 110953, 120725]);
p.destroy();
});
});
Expand Down
File renamed without changes.

0 comments on commit 7897b19

Please sign in to comment.