userList = [ 'admin' => Helper::makeUser('tgroup.a.' . randomString(6), 'tgroup'), 'user' => Helper::makeUser('tgroup.u.' . randomString(6), 'tgroup'), 'nope' => Helper::makeUser('tgroup.n.' . randomString(6), 'tgroup'), ]; $this->userList['admin']->requestContext()->setViewer($this->userList['admin']); $this->userList['admin']->setField('PermissionID', MOD)->modify(); $this->name = 'phpunit live in ' . randomString(6); $this->year = (int)date('Y'); $this->recordLabel = randomString(6) . ' Records'; $this->catalogueNumber = randomString(3) . '-' . random_int(1000, 2000); $this->manager = new Manager\TGroup(); $this->tgroup = $this->manager->create( categoryId: 1, name: $this->name, year: $this->year, recordLabel: $this->recordLabel, catalogueNumber: $this->catalogueNumber, description: "Description of {$this->name}", image: 'https://example.com/' . randomString(10) . '.jpg', releaseType: new ReleaseType()->findIdByName('Live album'), showcase: false, ); // and add some torrents to the group Helper::makeTorrentMusic( tgroup: $this->tgroup, user: $this->userList['user'], catalogueNumber: 'UA-TG-1', ); Helper::makeTorrentMusic( tgroup: $this->tgroup, user: $this->userList['admin'], catalogueNumber: 'UA-TG-1', format: 'MP3', encoding: 'V0', ); Helper::makeTorrentMusic( tgroup: $this->tgroup, user: $this->userList['user'], catalogueNumber: 'UA-TG-2', title: 'Limited Edition', ); } public function tearDown(): void { if (isset($this->tgroupExtra)) { Helper::removeTGroup($this->tgroupExtra, $this->userList['admin']); } Helper::removeTGroup($this->tgroup, $this->userList['admin']); foreach ($this->userList as $user) { $user->remove(); } } public function testTGroupCreate(): void { $this->assertGreaterThan(1, $this->tgroup->id, 'tgroup-create-id'); $this->assertTrue($this->tgroup->categoryGrouped(), 'tgroup-create-category-grouped'); $this->assertFalse($this->tgroup->isShowcase(), 'tgroup-create-showcase'); $this->assertFalse($this->tgroup->hasNoCoverArt(), 'tgroup-create-has-no-cover-art'); $this->assertCount(0, $this->tgroup->revisionList(), 'tgroup-create-revision-list'); $this->assertEquals('Music', $this->tgroup->categoryName(), 'tgroup-create-category-name'); $this->assertEquals('cats_music', $this->tgroup->categoryCss(), 'tgroup-create-category-ss'); $this->assertEquals('Live album', $this->tgroup->releaseTypeName(), 'tgroup-create-release-type-name'); $this->assertEquals($this->name, $this->tgroup->name(), 'tgroup-create-name'); $this->assertEquals($this->year, $this->tgroup->year(), 'tgroup-create-year'); $this->assertEquals($this->recordLabel, $this->tgroup->recordLabel(), 'tgroup-create-record-label'); $this->assertEquals($this->catalogueNumber, $this->tgroup->catalogueNumber(), 'tgroup-create-catalogue-number'); $this->assertEquals(0, $this->tgroup->unresolvedReportsTotal(), 'tgroup-create-unresolved-reports'); $this->assertEquals($this->tgroup->name(), $this->tgroup->flush()->name(), 'tgroup-create-flush'); $this->assertStringStartsWith('https://example.com/', (string)$this->tgroup->image(), 'tgroup-create-image'); $this->assertStringStartsWith('https://example.com/', $this->tgroup->cover(), 'tgroup-create-cover'); $this->assertTrue($this->tgroup->isOwner($this->userList['user']), 'tgroup-user-is-owner'); $this->assertTrue($this->tgroup->isOwner($this->userList['admin']), 'tgroup-admin-is-owner'); $this->assertFalse($this->tgroup->isOwner($this->userList['nope']), 'tgroup-nope-not-owner'); $this->assertNull($this->manager->findById(-666), 'tgroup-no-instance-of'); $find = $this->manager->findById($this->tgroup->id); $this->assertInstanceOf(TGroup::class, $find, 'tgroup-instance-of'); $this->assertEquals($this->tgroup->id, $find->id, 'tgroup-create-find'); $torMan = new Manager\Torrent(); $torrent = $torMan->findById($this->tgroup->torrentIdList()[0]); $this->assertInstanceOf(Torrent::class, $torrent, 'tgroup-found-torrent'); $this->assertEquals(1, $torrent->tokenCount(), 'tgroup-torrent-fl-cost'); $this->assertFalse($this->userList['user']->canSpendFLToken($torrent), 'tgroup-user-no-fltoken'); $bonus = (new User\Bonus($this->userList['user'])); $this->assertEquals(1, $bonus->addPoints(10000), 'tgroup-user-add-bp'); $this->assertEquals(1, $bonus->purchaseToken('token-1'), 'tgroup-user-buy-token'); $this->assertTrue($this->userList['user']->canSpendFLToken($torrent), 'tgroup-user-fltoken'); new Stats\Users()->refresh(); $this->assertEquals(2, $this->userList['user']->stats()->uploadTotal(), 'tgroup-user-stats-upload'); $this->assertEquals(1, $this->userList['user']->stats()->uniqueGroupTotal(), 'tgroup-user-stats-unique'); $this->assertEquals(1, $this->userList['admin']->stats()->uploadTotal(), 'tgroup-user-admin-upload'); $bookmarker = new User\Bookmark($this->userList['user']); $bookmarker->create('torrent', $this->tgroup->id); $page = $bookmarker->tgroupList(2, 0); $this->assertCount(1, $page, 'bookmark-tgroup-page-total'); $this->assertEquals( $this->tgroup->id, $page[0]['tgroup_id'], 'bookmark-tgroup-page-item' ); // no tags, but verify the SQL works $this->assertCount( 0, $bookmarker->tgroupTagLeaderboard(), 'bookmark-tag-leaderboard', ); $this->assertEquals( 1, $bookmarker->removeObject('torrent', $this->tgroup->id), 'tgroup-bookmark-user-remove', ); $bookmarker->create('torrent', $this->tgroup->id); $this->assertEquals( 1, $bookmarker->remove(), 'tgroup-bookmark-user-all-remove', ); } public function testTGroupArtist(): void { $artMan = new Manager\Artist(); $user = $this->userList['admin']; $artistName = 'phpunit ' . randomString(6) . ' band'; $this->assertEquals( 1, $this->tgroup->addArtists([ARTIST_MAIN], [$artistName]), 'tgroup-artist-add' ); $this->assertEquals( "$artistName – {$this->tgroup->name()} [{$this->tgroup->year()} Live album]", $this->tgroup->text(), 'tgroup-artist-text' ); $this->assertNotNull($this->tgroup->primaryArtist(), 'tgroup-artist-primary'); $artistRole = $this->tgroup->artistRole(); $this->assertNotNull($artistRole, 'tgroup-artist-artist-role'); $idList = $artistRole->idList(); $this->assertCount(1, $idList, 'tgroup-artist-role-idlist'); $main = $idList[ARTIST_MAIN]; $this->assertCount(1, $main, 'tgroup-artist-role-main'); $artist = $artMan->findByName($artistName); $this->assertEquals( [ "artists" => [[ "id" => $artist->id, "aliasid" => $artist->aliasId(), "name" => $artist->name(), ]], "with" => [], "remixedBy" => [], "composers" => [], "conductor" => [], "dj" => [], "producer" => [], "arranger" => [], ], $artistRole->roleListByType(), 'tgroup-artist-role-by-type', ); $this->assertEquals( [ "1" => [[ "id" => $artist->id, "aliasid" => $artist->aliasId(), "name" => $artist->name(), ]], "2" => null, "3" => null, "4" => null, "5" => null, "6" => null, "7" => null, "8" => null, ], $artistRole->legacyList(), 'tgroup-artist-role-legacy', ); $first = current($main); $this->assertEquals($artistName, $first['name'], 'tgroup-artist-first-name'); $foundByArtist = $this->manager->findByArtistReleaseYear( (string)$this->tgroup->artistRole()?->text(), $this->tgroup->name(), (int)$this->tgroup->releaseType(), (int)$this->tgroup->year(), ); $this->assertEquals( $this->tgroup->id, $foundByArtist?->id, 'tgroup-find-name' ); $addName = "$artistName-2"; $this->assertEquals( 2, $this->tgroup->addArtists( [ARTIST_MAIN, ARTIST_GUEST], [$addName, "$artistName-guest"], ), 'tgroup-artist-add-2' ); $this->assertInstanceOf( ArtistRole\TGroup::class, $this->tgroup->artistRole(), 'tgroup-has-artistrole' ); $this->assertEquals( [ ARTIST_MAIN => [$artistName, $addName], ARTIST_GUEST => ["$artistName-guest"], ], $this->tgroup->artistRole()->nameList(), 'tgroup-artist-name-list' ); /* turn the two Main and Guest into DJs */ $roleList = $this->tgroup->artistRole()?->roleList(); $this->assertIsArray($roleList, 'tgroup-dj-role'); $roleAliasList = [ ...array_map(fn ($artist) => [ARTIST_MAIN, $artist['aliasid']], $roleList['main']), ...array_map(fn ($artist) => [ARTIST_GUEST, $artist['aliasid']], $roleList['guest']), ]; $this->assertEquals( 3, $this->tgroup->artistRole()?->modifyList($roleAliasList, ARTIST_DJ, $user), 'tgroup-a-dj-saved-my-life' ); $this->assertEquals( 'Various DJs', $this->tgroup->flush()->artistRole()?->text(), 'tgroup-2manydjs' ); $this->assertEquals( 1, $this->tgroup->artistRole()?->removeList([[ARTIST_DJ, $roleAliasList[0][1]]], $user), 'tgroup-hang-the-dj' ); $this->assertEquals( "$addName and $artistName-guest", $this->tgroup->flush()->artistRole()?->text(), 'tgroup-dj-final' ); $this->assertEquals( [], $this->tgroup->artistRole()->matchName([]), 'match-name-none', ); $this->assertEquals( [$addName], $this->tgroup->artistRole()->matchName([strtoupper($addName)]), 'match-name-upper', ); } public function testTGroupCoverArt(): void { $coverId = $this->tgroup->addCoverArt( 'https://www.example.com/cover.jpg', 'cover art summary', ); $this->assertGreaterThan(0, $coverId, 'tgroup-cover-art-add'); $this->assertEquals( 1, $this->tgroup->removeCoverArt($coverId), 'tgroup-cover-art-del-ok' ); $this->assertEquals( 0, $this->tgroup->removeCoverArt(9999999), 'tgroup-cover-art-del-nok' ); } public function testTGroupRevision(): void { $revisionId = $this->tgroup->createRevision( $this->tgroup->description() . "\nmore text", 'https://www.example.com/image.jpg', 'phpunit testTGroup summary', ); $this->assertGreaterThan(0, $revisionId, 'tgroup-revision-add'); } public function testTGroupJson(): void { $json = new Json\TGroup( $this->tgroup, $this->userList['user'], new Manager\Torrent(), ); ['group' => $group, 'torrents' => $torrentList] = $json->payload(); $this->assertEquals( ["wikiBody", "wikiBBcode", "wikiImage", "proxyImage", "id", "name", "year", "recordLabel", "catalogueNumber", "releaseType", "releaseTypeName", "categoryId", "categoryName", "time", "vanityHouse", "isBookmarked", "tags", "musicInfo" ], array_keys($group), 'tgroup-json-group' ); $this->assertCount(3, $torrentList, 'tgroup-json-torrent-total'); $this->assertEquals( ["infoHash", "id", "media", "format", "encoding", "remastered", "remasterYear", "remasterTitle", "remasterRecordLabel", "remasterCatalogueNumber", "scene", "hasLog", "hasCue", "logScore", "logChecksum", "logCount", "ripLogIds", "fileCount", "size", "seeders", "leechers", "snatched", "freeTorrent", "reported", "time", "description", "fileList", "filePath", "userId", "username" ], array_keys($torrentList[0]), 'tgroup-json-torrent' ); $nope = new Json\TGroup( $this->tgroup, $this->userList['nope'], new Manager\Torrent(), ); // no infohash if not uploader $this->assertEquals( ["id", "media", "format", "encoding", "remastered", "remasterYear", "remasterTitle", "remasterRecordLabel", "remasterCatalogueNumber", "scene", "hasLog", "hasCue", "logScore", "logChecksum", "logCount", "ripLogIds", "fileCount", "size", "seeders", "leechers", "snatched", "freeTorrent", "reported", "time", "description", "fileList", "filePath", "userId", "username" ], array_keys($nope->payload()['torrents'][0]), 'tgroup-json-nope-torrent' ); } public function testTGroupSubscription(): void { $sub = new User\Subscription($this->userList['user']); $this->assertTrue($sub->subscribeComments('torrents', $this->tgroup->id)); $text = 'phpunit tgroup subscribe ' . randomString(); $commentMan = new Manager\Comment(); $comment = $commentMan->create($this->userList['admin'], 'torrents', 0, $text); // TODO: should this be 1? $this->assertEquals(0, $comment->pageNum(), 'tgroup-comment-page-num'); $this->assertEquals([['torrents', $this->tgroup->id]], $sub->commentSubscriptions(), 'tgroup-tgroup-comment-sub'); $this->assertEquals(1, $sub->commentTotal(), 'tgroup-tgroup-comment-all'); } public function testTGroupTag(): void { $user = $this->userList['admin']; $name = 'phpunit.' . randomString(6); $tagMan = new Manager\Tag(); $tag = $tagMan->create($name, $user); $this->assertGreaterThan(1, $tag->id, 'tgroup-tag-create'); $this->assertEquals(1, $tag->addTGroup($this->tgroup, $user, 10), 'tgroup-tag-add-one'); $tag2 = $tagMan->create('phpunit.' . randomString(6), $user); $this->assertEquals(1, $tag2->addTGroup($this->tgroup, $user, 5), 'tgroup-tag-add-two'); $this->tgroup->flush(); $this->assertCount(2, $this->tgroup->tagNameList(), 'tgroup-tag-name-list'); $this->assertContains($name, $this->tgroup->tagNameList(), 'tgroup-tag-name-find-one'); $this->assertContains($tag2->name(), $this->tgroup->tagNameList(), 'tgroup-tag-name-find-not'); $this->assertEquals("#{$name} #{$tag2->name()}", $this->tgroup->hashTag(), 'tgroup-tag-name-list'); $this->assertEquals(1, $tag->voteTGroup($this->tgroup, $user, 'up'), 'tgroup-tag-upvote'); $this->assertEquals(1, $tag2->voteTGroup($this->tgroup, $user, 'down'), 'tgroup-tag-downvote'); $this->assertEquals(ucfirst($name), $this->tgroup->primaryTag(), 'tgroup-tag-primary'); $this->assertTrue($tag2->removeTGroup($this->tgroup), 'tgroup-tag-remove-exists'); $tag3 = $tagMan->create('phpunit.' . randomString(6), $user); $this->assertFalse($tag3->removeTGroup($this->tgroup), 'tgroup-tag-remove-not-exists'); } public function testLatestUploads(): void { // we can at least test the SQL $this->assertGreaterThanOrEqual( 0, count(new Manager\Torrent()->latestUploads(5)), 'tgroup-latest-uploads' ); } public function testTGroupMerge(): void { $admin = $this->userList['admin']; $user = $this->userList['user']; $this->tgroupExtra = $this->manager->create( categoryId: 1, name: $this->name . ' merge ' . randomString(10), year: $this->year, recordLabel: $this->recordLabel, catalogueNumber: $this->catalogueNumber, description: "Description of {$this->name} merge", image: '', releaseType: new ReleaseType()->findIdByName('Live album'), showcase: false, ); Helper::makeTorrentMusic( tgroup: $this->tgroupExtra, user: $user, catalogueNumber: 'UA-MG-1', ); $oldId = $this->tgroupExtra->id; $oldName = $this->tgroupExtra->name(); new User\Bookmark($admin)->create('torrent', $oldId); new Manager\Comment()->create($user, 'torrents', $oldId, 'phpunit comment ' . randomString(10)); $adminVote = new User\Vote($admin); $userVote = new User\Vote($user); $adminVote->upvote($this->tgroupExtra); $userVote->downvote($this->tgroupExtra); $this->assertTrue( $this->manager->merge( $this->tgroupExtra, $this->tgroup, $this->userList['admin'], new Manager\User(), new Manager\Vote(), ), 'tgroup-music-merge' ); $siteLog = new Manager\SiteLog(); $list = $siteLog->tgroupLogList($this->tgroup->id); $event = end($list); $this->assertStringContainsString("($oldName)", $event['info'], 'tgroup-merge-old-name'); $this->assertStringContainsString("({$this->tgroup->name()})", $event['info'], 'tgroup-merge-new-name'); $general = current($siteLog->page(1, 0, '')); $this->assertEquals( "Group $oldId deleted following merge to {$this->tgroup->id}.", $general['message'], 'tgroup-merge-general' ); // create new vote objects to pick up the state change unset($adminVote); unset($userVote); $adminVote = new User\Vote($admin); $userVote = new User\Vote($user); $this->assertEquals(1, $adminVote->flush()->vote($this->tgroup), 'tgroup-merge-upvote'); $this->assertEquals(-1, $userVote->flush()->vote($this->tgroup), 'tgroup-merge-downvote'); } public function testTGroupSplit(): void { $list = $this->tgroup->torrentIdList(); $this->assertCount(3, $list, 'tgroup-has-torrents'); $torrent = new Manager\Torrent()->findById($list[1]); $this->assertInstanceOf(Torrent::class, $torrent, 'tgroup-id-is-a-torrent'); $suffix = randomString(10); $this->tgroupExtra = new Manager\TGroup()->createFromTorrent( $torrent, "phpunit split artist $suffix", "php split title $suffix", (int)date('Y'), new Manager\Artist(), new Manager\Bookmark(), new Manager\Comment(), new Manager\Vote(), $this->userList['admin'], ); $this->assertInstanceOf(TGroup::class, $this->tgroupExtra, 'tgroup-is-split'); $this->assertCount(2, $this->tgroup->flush()->torrentIdList(), 'tgroup-has-one-less-torrent'); $this->assertCount(1, $this->tgroupExtra->torrentIdList(), 'tgroup-split-has-one-torrent'); } public function testReleaseType(): void { global $Cache; $Cache->delete_value(ReleaseType::CACHE_KEY); $releaseType = new ReleaseType(); $this->assertCount(17, $releaseType->list(), 'rel-type-list'); $this->assertCount( 22, $releaseType->extendedList(), 'rel-type-extended-list', ); $this->assertEquals( 6, $releaseType->findIdByName('Anthology'), 'rel-type-find-id', ); $this->assertEquals( 'Anthology', $releaseType->findNameById(6), 'rel-type-find-name', ); $this->assertEquals( 'DJ Mixes', $releaseType->sectionTitle($releaseType->findIdByName('DJ Mix')), 'rel-type-section-title', ); } public function testStatsRefresh(): void { $this->assertGreaterThanOrEqual( 0, new Stats\TGroups()->refresh(), 'tgroup-stats-refresh' ); } public function testRemasterList(): void { $list = $this->tgroup->remasterList(); $id_list = $this->tgroup->torrentIdList(); $this->assertCount(2, $list, 'tgroup-remaster-list'); $this->assertEquals([$id_list[0]], $list[0]['id_list'], 'tgroup-remaster-list-0-id-list'); $this->assertEquals([$id_list[1], $id_list[2]], $list[1]['id_list'], 'tgroup-remaster-list-1-id-list'); $this->assertEquals('Limited Edition', $list[0]['title'], 'tgroup-remaster-title'); $this->assertEquals('UA-TG-2', $list[0]['catalogue_number'], 'tgroup-remaster-cat-no'); $this->assertEquals('Unitest Artists', $list[0]['record_label'], 'tgroup-remaster-rec-label'); } public function testTGroupStats(): void { new Stats\TGroups()->refresh(); $stats = $this->tgroup->stats(); $this->assertGreaterThanOrEqual(0, $stats->downloadTotal(), 'tgroup-stats-download'); $this->assertGreaterThanOrEqual(0, $stats->leechTotal(), 'tgroup-stats-leech'); $this->assertGreaterThanOrEqual(0, $stats->seedingTotal(), 'tgroup-stats-seeding'); $this->assertGreaterThanOrEqual(0, $stats->snatchTotal(), 'tgroup-stats-snatch'); // test increment $total = $stats->bookmarkTotal(); $bookmarker = new User\Bookmark($this->userList['user']); $bookmarker->create('torrent', $this->tgroup->id); new Stats\TGroups()->refresh(); $stats->flush(); $this->assertEquals($total + 1, $stats->bookmarkTotal(), 'tgroup-stats-update-bookmark'); $this->assertTrue( $bookmarker->isTGroupBookmarked($this->tgroup), 'tgroup-merge-bookmark', ); $list = $bookmarker->tgroupBookmarkList(); $this->assertCount(1, $list, 'tgroup-bookmark-user-total'); $this->assertEquals( $this->tgroup->id, $list[0]['tgroup_id'], 'tgroup-bookmark-user-id', ); $this->assertEquals( 3, $bookmarker->torrentTotal(), 'tgroup-bookmark-tgroup-total', ); // artists have not been assigned, but this tests the SQL $this->assertEquals( [], $bookmarker->tgroupArtistLeaderboard(), 'tgroup-bookmark-leaderboard', ); $this->assertEquals( 0, $bookmarker->tgroupArtistTotal(), 'tgroup-bookmark-artist-total', ); Helper::generateTorrentSnatch( new Torrent($this->tgroup->torrentIdList()[0]), $bookmarker->user() ); $this->assertEquals( 1, $bookmarker->removeSnatched(), 'tgroup-bookmark-remove-snatched', ); } }