File: tst_rhythmicGrouping.cpp

package info (click to toggle)
musescore2 2.3.2%2Bdfsg4-16
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 170,464 kB
  • sloc: cpp: 262,612; xml: 176,707; sh: 3,377; ansic: 1,246; python: 356; makefile: 227; perl: 82; pascal: 78
file content (82 lines) | stat: -rw-r--r-- 3,136 bytes parent folder | download | duplicates (4)
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
//=============================================================================
//  MuseScore
//  Music Composition & Notation
//  $Id:$
//
//  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"

#define DIR QString("libmscore/rhythmicGrouping/")

using namespace Ms;

//---------------------------------------------------------
//   TestRhythmicGrouping
//---------------------------------------------------------

class TestRhythmicGrouping : public QObject, public MTest
      {
      Q_OBJECT

      void group(const char* p1, const char* p2, int staves = 0);

   private slots:
      void initTestCase();
      void group8ths44()             { group("group8ths4-4.mscx",           "group8ths4-4-ref.mscx");      }
      void group8thsSimple()         { group("group8thsSimple.mscx",        "group8thsSimple-ref.mscx");   }
      void group8thsCompound()       { group("group8thsCompound.mscx",      "group8thsCompound-ref.mscx"); }
      void groupSubbeats()           { group("groupSubbeats.mscx",          "groupSubbeats-ref.mscx");     }
      void groupVoices()             { group("groupVoices.mscx",            "groupVoices-ref.mscx");       }
      void groupConflicts()          { group("groupConflicts.mscx",         "groupConflicts-ref.mscx", 1); } // only group 1st staff
      void groupArticulationsTies()  { group("groupArticulationsTies.mscx", "groupArticulationsTies-ref.mscx"); } // test for articulations and forward/backward ties
      void groupShortenNotes()       { group("groupShortenNotes.mscx",      "groupShortenNotes-ref.mscx"); } // test for regrouping rhythms when notes should be shortened

      };

//---------------------------------------------------------
//   initTestCase
//---------------------------------------------------------

void TestRhythmicGrouping::initTestCase()
      {
      initMTest();
      }

//---------------------------------------------------------
//   group
//---------------------------------------------------------

void TestRhythmicGrouping::group(const char* p1, const char* p2, int staves)
      {
      Score* score = readScore(DIR + p1);
      score->doLayout();

      if (!staves) {
            score->cmdSelectAll();
            score->cmdResetNoteAndRestGroupings();
            }
      else {
            Q_ASSERT(staves < score->nstaves());
            score->startCmd();
            for (int track = 0; track < staves * VOICES; track++)
                  score->regroupNotesAndRests(score->firstSegment()->tick(), score->lastSegment()->tick(), track);
            score->endCmd();
            }

      score->doLayout();
      QVERIFY(saveCompareScore(score, p1, DIR + p2));
      delete score;
      }

QTEST_MAIN(TestRhythmicGrouping)
#include "tst_rhythmicGrouping.moc"