1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2012 Werner Schweer
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2
// as published by the Free Software Foundation and appearing in
// the file LICENCE.GPL
//=============================================================================
#include <QtTest/QtTest>
#include "mtest/testutils.h"
#include "libmscore/score.h"
#include "libmscore/measure.h"
#include "libmscore/chordrest.h"
#define DIR QString("libmscore/beam/")
using namespace Ms;
//---------------------------------------------------------
// TestBeam
//---------------------------------------------------------
class TestBeam : public QObject, public MTest
{
Q_OBJECT
void beam(const char* path);
private slots:
void initTestCase();
void beamA() { beam("Beam-A.mscx"); }
void beamB() { beam("Beam-B.mscx"); }
void beamC() { beam("Beam-C.mscx"); }
void beamD() { beam("Beam-D.mscx"); }
void beamE() { beam("Beam-E.mscx"); }
void beamF() { beam("Beam-F.mscx"); }
void beamG() { beam("Beam-G.mscx"); }
void beam2() { beam("Beam-2.mscx"); }
void beam23() { beam("Beam-23.mscx"); }
void beamS0() { beam("Beam-S0.mscx"); }
void beamDir() { beam("Beam-dir.mscx"); }
void beamCrossMeasure1();
void beamCrossMeasure2() { beam("Beam-CrossM2.mscx"); }
void beamCrossMeasure3() { beam("Beam-CrossM3.mscx"); }
void beamCrossMeasure4() { beam("Beam-CrossM4.mscx"); }
};
//---------------------------------------------------------
// initTestCase
//---------------------------------------------------------
void TestBeam::initTestCase()
{
initMTest();
}
//---------------------------------------------------------
// beam
//---------------------------------------------------------
void TestBeam::beam(const char* path)
{
MasterScore* score = readScore(DIR + path);
QVERIFY(score);
QVERIFY(saveCompareScore(score, path, DIR + path));
delete score;
}
//---------------------------------------------------------
// beamCrossMeasure1
// This method simulates following operations:
// - Update the score
// - Check if the beam has been recreated. If yes, this is wrong behaviour
//---------------------------------------------------------
void TestBeam::beamCrossMeasure1()
{
MasterScore* score = readScore(DIR + "Beam-CrossM1.mscx");
QVERIFY(score);
Measure* first_measure = score->firstMeasure();
// find the first segment that has a chord
Segment* s = first_measure->first(SegmentType::ChordRest);
while (s && !s->element(0)->isChord())
s = s->next(SegmentType::ChordRest);
// locate the first beam
ChordRest* first_note = toChordRest(s->element(0));
Beam* b = first_note->beam();
score->update();
// locate the beam again, and check if it is still b
Beam* new_b = first_note->beam();
QCOMPARE(new_b, b);
delete score;
}
QTEST_MAIN(TestBeam)
#include "tst_beam.moc"
|