OSMD_Test.ts 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. import chai = require("chai");
  2. import { OpenSheetMusicDisplay } from "../../../src/OpenSheetMusicDisplay/OpenSheetMusicDisplay";
  3. import { TestUtils } from "../../Util/TestUtils";
  4. describe("OpenSheetMusicDisplay Main Export", () => {
  5. let container1: HTMLElement;
  6. it("no container", (done: MochaDone) => {
  7. chai.expect(() => {
  8. return new OpenSheetMusicDisplay(undefined);
  9. }).to.throw(/container/);
  10. done();
  11. });
  12. it("container", (done: MochaDone) => {
  13. const div: HTMLElement = TestUtils.getDivElement(document);
  14. chai.expect(() => {
  15. return new OpenSheetMusicDisplay(div);
  16. }).to.not.throw(Error);
  17. done();
  18. });
  19. it("load MXL from string", (done: MochaDone) => {
  20. const mxl: string = TestUtils.getMXL("Mozart_Clarinet_Quintet_Excerpt.mxl");
  21. const div: HTMLElement = TestUtils.getDivElement(document);
  22. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  23. opensheetmusicdisplay.load(mxl).then(
  24. (_: {}) => {
  25. opensheetmusicdisplay.render();
  26. done();
  27. },
  28. done
  29. );
  30. });
  31. it("load invalid MXL from string", (done: MochaDone) => {
  32. const mxl: string = "\x50\x4b\x03\x04";
  33. const div: HTMLElement = TestUtils.getDivElement(document);
  34. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  35. opensheetmusicdisplay.load(mxl).then(
  36. (_: {}) => {
  37. done(new Error("Corrupted MXL appears to be loaded correctly"));
  38. },
  39. (exc: Error) => {
  40. if (exc.message.toLowerCase().match(/invalid/)) {
  41. done();
  42. } else {
  43. done(new Error("Unexpected error: " + exc.message));
  44. }
  45. }
  46. );
  47. });
  48. it("load XML string", (done: MochaDone) => {
  49. const score: Document = TestUtils.getScore("MuzioClementi_SonatinaOpus36No1_Part1.xml");
  50. const xml: string = new XMLSerializer().serializeToString(score);
  51. const div: HTMLElement = TestUtils.getDivElement(document);
  52. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  53. opensheetmusicdisplay.load(xml).then(
  54. (_: {}) => {
  55. opensheetmusicdisplay.render();
  56. },
  57. done
  58. );
  59. });
  60. it("load XML Document", (done: MochaDone) => {
  61. const score: Document = TestUtils.getScore("MuzioClementi_SonatinaOpus36No1_Part1.xml");
  62. const div: HTMLElement = TestUtils.getDivElement(document);
  63. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  64. opensheetmusicdisplay.load(score).then(
  65. (_: {}) => {
  66. opensheetmusicdisplay.render();
  67. done();
  68. },
  69. done
  70. );
  71. });
  72. it("Timeout from server", (done: MochaDone) => {
  73. const score: string = "https://httpstat.us/408";
  74. const div: HTMLElement = TestUtils.getDivElement(document);
  75. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  76. opensheetmusicdisplay.load(score).then(
  77. (_: {}) => {
  78. done(new Error("Unexpected response from server"));
  79. },
  80. (exc: Error) => {
  81. done();
  82. }
  83. );
  84. });
  85. it("load MXL Document by URL", (done: MochaDone) => {
  86. const url: string = "base/test/data/Mozart_Clarinet_Quintet_Excerpt.mxl";
  87. const div: HTMLElement = TestUtils.getDivElement(document);
  88. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  89. opensheetmusicdisplay.load(url).then(
  90. (_: {}) => {
  91. opensheetmusicdisplay.render();
  92. done();
  93. },
  94. done
  95. );
  96. });
  97. it("load something invalid by URL", (done: MochaDone) => {
  98. const url: string = "https://www.google.com";
  99. const div: HTMLElement = TestUtils.getDivElement(document);
  100. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  101. opensheetmusicdisplay.load(url).then(
  102. (_: {}) => {
  103. done(new Error("Invalid URL appears to be loaded correctly"));
  104. },
  105. (exc: Error) => {
  106. if (exc.message.toLowerCase().match(/opensheetmusicdisplay.*invalid/)) {
  107. done();
  108. } else {
  109. done(new Error("Unexpected error: " + exc.message));
  110. }
  111. }
  112. );
  113. }).timeout(5000);
  114. it("load invalid URL", (done: MochaDone) => {
  115. const url: string = "https://www.afjkhfjkauu2ui3z2uiu.com";
  116. const div: HTMLElement = TestUtils.getDivElement(document);
  117. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  118. opensheetmusicdisplay.load(url).then(
  119. (_: {}) => {
  120. done(new Error("Invalid URL appears to be loaded correctly"));
  121. },
  122. (exc: Error) => {
  123. if (exc.message.toLowerCase().match(/url/)) {
  124. done();
  125. } else {
  126. done(new Error("Unexpected error: " + exc.message));
  127. }
  128. }
  129. );
  130. }).timeout(5000);
  131. it("load invalid XML string", (done: MochaDone) => {
  132. const xml: string = "<?xml";
  133. const div: HTMLElement = TestUtils.getDivElement(document);
  134. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  135. opensheetmusicdisplay.load(xml).then(
  136. (_: {}) => {
  137. done(new Error("Corrupted XML appears to be loaded correctly"));
  138. },
  139. (exc: Error) => {
  140. if (exc.message.toLowerCase().match(/partwise/)) {
  141. done();
  142. } else {
  143. done(new Error("Unexpected error: " + exc.message));
  144. }
  145. }
  146. );
  147. });
  148. it("render without loading", (done: MochaDone) => {
  149. const div: HTMLElement = TestUtils.getDivElement(document);
  150. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  151. chai.expect(() => {
  152. return opensheetmusicdisplay.render();
  153. }).to.throw(/load/);
  154. done();
  155. });
  156. before((): void => {
  157. // Create the container for the "test width" test
  158. container1 = TestUtils.getDivElement(document);
  159. });
  160. after((): void => {
  161. // Destroy the container for the "test width" test
  162. document.body.removeChild(container1);
  163. });
  164. it("test width 500", (done: MochaDone) => {
  165. const div: HTMLElement = container1;
  166. div.style.width = "500px";
  167. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  168. const score: Document = TestUtils.getScore("MuzioClementi_SonatinaOpus36No1_Part1.xml");
  169. opensheetmusicdisplay.load(score).then(
  170. (_: {}) => {
  171. opensheetmusicdisplay.render();
  172. chai.expect(div.offsetWidth).to.equal(500);
  173. done();
  174. },
  175. done
  176. ).catch(done);
  177. });
  178. it("test width 200", (done: MochaDone) => {
  179. const div: HTMLElement = container1;
  180. div.style.width = "200px";
  181. const opensheetmusicdisplay: OpenSheetMusicDisplay = TestUtils.createOpenSheetMusicDisplay(div);
  182. const score: Document = TestUtils.getScore("MuzioClementi_SonatinaOpus36No1_Part1.xml");
  183. opensheetmusicdisplay.load(score).then(
  184. (_: {}) => {
  185. opensheetmusicdisplay.render();
  186. chai.expect(div.offsetWidth).to.equal(200);
  187. done();
  188. },
  189. done
  190. ).catch(done);
  191. });
  192. describe("cursor with hidden instrument", () => {
  193. let osmd: OpenSheetMusicDisplay;
  194. beforeEach(() => {
  195. const div: HTMLElement = TestUtils.getDivElement(document);
  196. osmd = TestUtils.createOpenSheetMusicDisplay(div);
  197. const score: Document =
  198. TestUtils.getScore("MuzioClementi_SonatinaOpus36No1_Part1.xml");
  199. return osmd.load(score)
  200. .then(() => {
  201. osmd.render();
  202. });
  203. });
  204. it("should move cursor after instrument is hidden", () => {
  205. osmd.Sheet.Instruments[1].Visible = false;
  206. osmd.render();
  207. osmd.cursor.show();
  208. for (let i: number = 0; i < 100; i++) {
  209. osmd.cursor.next();
  210. }
  211. });
  212. });
  213. });