/*
* Copyright [1999-2015] Wellcome Trust Sanger Institute and the EMBL-European Bioinformatics Institute
* Copyright [2016-2017] EMBL-European Bioinformatics Institute
*
* 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.
*/
/**
* File: GeneDescriptionSourceTest.java
* Created by: dstaines
* Created on: May 26, 2009
* CVS: $$
*/
package org.ensembl.healthcheck.testcase.eg_core;
import org.ensembl.healthcheck.DatabaseType;
import org.ensembl.healthcheck.Team;
import org.ensembl.healthcheck.testcase.AbstractIntegerTestCase;
/**
* Test to see if we're using display_xrefs that are the same as the stable_id
*
* @author dstaines
*
*/
public class GeneStableIdDisplayXref extends AbstractIntegerTestCase {
public GeneStableIdDisplayXref() {
super();
this.addToGroup(AbstractEgCoreTestCase.EG_GROUP);
this.appliesToType(DatabaseType.CORE);
this.setTeamResponsible(Team.ENSEMBL_GENOMES);
this.setFix("update gene g, xref x set g.display_xref_id=NULL "
+ "where g.display_xref_id=x.xref_id and x.display_label=g.stable_id and biotype='protein_coding'");
}
/*
* (non-Javadoc)
*
* @see org.ensembl.healthcheck.testcase.AbstractIntegerTestCase#getSql()
*/
@Override
protected String getSql() {
return "select count(*) from gene g join xref x on (g.display_xref_id=x.xref_id) where x.display_label=g.stable_id";
}
@Override
protected String getErrorMessage(int count) {
return count + " genes found with stable_id set as display_xrefs";
}
@Override
protected boolean testValue(int value) {
return value == 0;
}
}