query($sql); // Add a file $values = array("filepath" => dirname(__FILE__)."/test10001.mp3"); $this->storedFile = StoredFile::Insert($values, false); // Add a file $values = array("filepath" => dirname(__FILE__)."/test10002.mp3"); $this->storedFile2 = StoredFile::Insert($values, false); // Clear the schedule table //$sql = "DELETE FROM ".$CC_CONFIG["scheduleTable"]; //$CC_DBC->query($sql); } function testDateToId() { $dateStr = "2006-04-02 10:20:08.123456"; $id = ScheduleGroup::dateToId($dateStr); $expected = "20060402102008123"; if ($id != $expected) { $this->fail("Did not convert date to ID correctly #1: $id != $expected"); } $dateStr = "2006-04-02 10:20:08"; $id = ScheduleGroup::dateToId($dateStr); $expected = "20060402102008000"; if ($id != $expected) { $this->fail("Did not convert date to ID correctly #2: $id != $expected"); } } function testAddAndRemoveAudioFile() { $i = new ScheduleGroup(); $this->groupIdCreated = $i->add('2010-10-10 01:30:23', $this->storedFile->getId()); if (PEAR::isError($this->groupIdCreated)) { $this->fail("Failed to create scheduled item: ". $this->groupIdCreated->getMessage()); } $i = new ScheduleGroup($this->groupIdCreated); $result = $i->remove(); if ($result != 1) { $this->fail("Did not remove item."); } } function testAddAndRemovePlaylist() { // Create a playlist $playlist = new Playlist(); $playlist->create("Scheduler Unit Test ".uniqid()); $result = $playlist->addAudioClip($this->storedFile->getId()); $result = $playlist->addAudioClip($this->storedFile2->getId()); $result = $playlist->addAudioClip($this->storedFile2->getId()); $i = new ScheduleGroup(); $this->groupIdCreated = $i->add('2010-11-11 01:30:23', null, $playlist->getId()); if (PEAR::isError($this->groupIdCreated)) { $this->fail("Failed to create scheduled item: ". $this->groupIdCreated->getMessage()); } $group = new ScheduleGroup($this->groupIdCreated); if ($group->count() != 3) { $this->fail("Wrong number of items added."); } $items = $group->getItems(); if (!is_array($items) || ($items[1]["starts"] != "2010-11-11 01:30:34.231")) { $this->fail("Wrong start time for 2nd item."); } $result = $group->remove(); if ($result != 1) { $this->fail("Did not remove item."); } Playlist::Delete($playlist->getId()); } function testIsScheduleEmptyInRange() { $i = new ScheduleGroup(); $this->groupIdCreated = $i->add('2011-10-10 01:30:23', $this->storedFile->getId()); if (PEAR::isError($this->groupIdCreated)) { $this->fail($this->groupIdCreated->getMessage()); return; } if (Schedule::isScheduleEmptyInRange('2011-10-10 01:30:23', '00:00:12.555')) { $this->fail("Reporting empty schedule when it isnt."); return; } // echo "groupid: ".$this->groupIdCreated."\n"; $success = $i->remove(); if ($success === false) { $this->fail("Failed to delete schedule group."); return; } if (!Schedule::isScheduleEmptyInRange('2011-10-10 01:30:23', '00:00:12.555')) { $this->fail("Reporting booked schedule when it isnt."); return; } } function testGetItems() { $i1 = new ScheduleGroup(); $groupId1 = $i1->add('2008-01-01 12:00:00.000', $this->storedFile->getId()); $i2 = new ScheduleGroup(); $i2->addAfter($groupId1, $this->storedFile->getId()); $items = Schedule::GetItems("2008-01-01", "2008-01-02"); if (count($items) != 2) { $this->fail("Wrong number of items returned."); return; } $i1->remove(); $i2->remove(); } } ?>