mirror of
https://github.com/FunkinCrew/Funkin.git
synced 2024-12-02 04:17:07 -05:00
42d8d55067
* Initial test suite * Fix some build warnings * Implemented working unit tests with coverage * Reduced some warnings * Fix a mac-specific issue * Add 2 additional unit test classes. * Multiple new unit tests * Some fixins * Remove auto-generated file * WIP on hiding ignored tests * Added list of debug hotkeys * Remove old website * Remove empty file * Add more unit tests * Fix bug where arrows would nudge BF * Fix bug where ctrl/alt would flash capsules * Fixed bug where bf-old easter egg broke * Remove duplicate lines * More test-related stuff * Some code cleanup * Add mocking and a test assets folder * More TESTS! * Update Hmm... * Update artist on Monster * More minor fixes to individual functions * 1.38% unit test coverage! * Even more tests? :O * More unit test work * Rework migration for BaseRegistry * gameover fix * Fix an issue with Lime * Fix issues with version parsing on data files * 100 total unit tests! * Added even MORE unit tests! * Additional test tweaks :3 * Fixed tests on windows by updating libraries. * Set versions for flixel-ui and hamcrest --------- Co-authored-by: Cameron Taylor <cameron.taylor.ninja@gmail.com>
90 lines
2.3 KiB
Haxe
90 lines
2.3 KiB
Haxe
package funkin.data.notestyle;
|
|
|
|
import funkin.data.notestyle.NoteStyleRegistry;
|
|
import funkin.play.notes.notestyle.NoteStyle;
|
|
import massive.munit.Assert;
|
|
import massive.munit.async.AsyncFactory;
|
|
import massive.munit.util.Timer;
|
|
|
|
@:access(funkin.play.notes.notestyle.NoteStyle)
|
|
@:access(funkin.data.notestyle.NoteStyleRegistry)
|
|
class NoteStyleRegistryTest extends FunkinTest
|
|
{
|
|
public function new()
|
|
{
|
|
super();
|
|
}
|
|
|
|
@BeforeClass
|
|
public function beforeClass()
|
|
{
|
|
NoteStyleRegistry.instance.loadEntries();
|
|
}
|
|
|
|
@AfterClass
|
|
public function afterClass() {}
|
|
|
|
@Before
|
|
public function setup() {}
|
|
|
|
@After
|
|
public function tearDown() {}
|
|
|
|
@Test
|
|
public function testValid()
|
|
{
|
|
Assert.isNotNull(NoteStyleRegistry.instance);
|
|
}
|
|
|
|
@Test
|
|
public function testParseEntryData()
|
|
{
|
|
var result:NoteStyleData = NoteStyleRegistry.instance.parseEntryData("test2");
|
|
|
|
Assert.areEqual(result.version, "1.0.0");
|
|
Assert.areEqual(result.name, "Test2");
|
|
Assert.areEqual(result.author, "Eric");
|
|
Assert.areEqual(result.fallback, "funkin");
|
|
|
|
Assert.areEqual(result.assets.note.assetPath, "shared:coolstuff");
|
|
Assert.areEqual(result.assets.note.scale, 1.8);
|
|
Assert.areEqual(result.assets.note.data.left.prefix, "noteLeft1");
|
|
Assert.areEqual(result.assets.note.data.down.prefix, "noteDown3");
|
|
Assert.areEqual(result.assets.note.data.up.prefix, "noteUp2");
|
|
Assert.areEqual(result.assets.note.data.right.prefix, "noteRight4");
|
|
}
|
|
|
|
@Test
|
|
public function testFetchEntry()
|
|
{
|
|
var result:NoteStyle = NoteStyleRegistry.instance.fetchEntry("test2");
|
|
|
|
Assert.areEqual(result.toString(), "NoteStyle(test2)");
|
|
Assert.areEqual(result.getName(), "Test2");
|
|
Assert.areEqual(result.getAuthor(), "Eric");
|
|
Assert.areEqual(result.getFallbackID(), "funkin");
|
|
}
|
|
|
|
@Test
|
|
public function testFetchBadEntry()
|
|
{
|
|
var result:NoteStyle = NoteStyleRegistry.instance.fetchEntry("blablabla");
|
|
|
|
Assert.areEqual(result, null);
|
|
}
|
|
|
|
@Test
|
|
public function testFetchDefault()
|
|
{
|
|
var nsrMock:NoteStyleRegistry = mock(NoteStyleRegistry);
|
|
|
|
nsrMock.fetchDefault().callsRealMethod();
|
|
|
|
// Perform the call.
|
|
nsrMock.fetchDefault();
|
|
|
|
// Verify the underlying call.
|
|
|
|
nsrMock.fetchEntry(NoteStyleRegistry.DEFAULT_NOTE_STYLE_ID).verify(times(1));
|
|
}
|
|
}
|