Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/job-board.corals.io/vendor/aweber/aweber/tests/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/job-board.corals.io/vendor/aweber/aweber/tests/AWeberCollectionTest.php
<?php
require_once('aweber_api/aweber_api.php');
require_once('mock_adapter.php');


class TestFindCollection extends PHPUnit_Framework_TestCase {

    public function setUp() {
        $url = '/accounts/1/lists/303449/subscribers';
        $this->adapter = get_mock_adapter();
        $this->subscribers = new AWeberCollection(
            $this->adapter->request('GET', $url), 
            $url,
            $this->adapter);
        $this->adapter->clearRequests();
        $this->params = array('status' => 'unsubscribed', 'ws.size' => 1, 'ws.start' => 0);
        $this->found = $this->subscribers->find($this->params);
    }

    /**
     * Test to ensure that the nested objects, such as "custom_fields", are formatted correctly for GET request.  The
     * nested objects should be a JSON encoded string.
     */
    public function testFormatOfGetData() {
        $findParams = array('custom_fields' => array('test' => 'test'));
        $expectedUri = '/accounts/1/lists/303449/subscribers?custom_fields=%7B%22test%22%3A%22test%22%7D&ws.op=find';

        $this->adapter->clearRequests();

        $resp = $this->subscribers->find($findParams);

        $req = $this->adapter->requestsMade[0];
        $this->assertEquals($req['method'], 'GET');
        $this->assertEquals($expectedUri, $req['uri']);
        $this->assertEmpty($req['headers'], "Find request shouldn't have a Content-Type header");
    }

    /**
     * Checks that the nested objects, such as "custom_fields", are formatted correctly.  The "create" method
     * is a POST with Content-Type of 'application/json'.  The data should be formatted as JSON.
     */
    public function testFormatOfPostData() {

        $createParams = array(
            'email' => '[email protected]',
            'ip_address' => '127.0.0.1',
            'name' => 'John Doe',
            'custom_fields' => array(
                'custom' => 'test'
            )
        );

        $expectedCreateParams = array(
            'ws.op' => 'create',
            'email' => '[email protected]',
            'ip_address' => '127.0.0.1',
            'name' => 'John Doe',
            'custom_fields' => array(
                'custom' => 'test'
            )
        );

        $this->adapter->clearRequests();

        $resp = $this->subscribers->create($createParams);

        $req = $this->adapter->requestsMade[0];
        $this->assertEquals($req['method'], 'POST');
        $this->assertEquals($req['data'], $expectedCreateParams);
        $this->assertEquals(array('Content-Type: application/json'), $req['headers'], "Create request should have a Content-Type header");

    }

    /**
     * The find method makes two requests, one for the collection, and the other to get total_size.
     */
    public function testShouldInitiallyMake2APIRequests() {
        $this->assertEquals(count($this->adapter->requestsMade), 2);
    }

    /**
     * The first of two requests, verify the url to get the collection.
     */
    public function testShouldRequestCollectionPageFirst() {
        #$this->subscribers->find($this->params);
        $uri = $this->adapter->requestsMade[0]['uri'];
        $this->assertEquals($uri, '/accounts/1/lists/303449/subscribers?status=unsubscribed&ws.op=find&ws.size=1&ws.start=0');
    }

    /**
     * The second of two requests, verify the url to get the total size.
     */
    public function testShouldRequestTotalSizePageSecond() {
        $uri = $this->adapter->requestsMade[1]['uri'];
        $this->assertEquals($uri, '/accounts/1/lists/303449/subscribers?status=unsubscribed&ws.op=find&ws.show=total_size&ws.size=1&ws.start=0');
    }

    /**
     * Pagination: An additional fetch is made when there is a next_collection_link included 
     */
    public function testShouldFetchDataforDataNotPreviouslyLoaded() {
        $this->adapter->clearRequests();
        $subscriber = $this->found[1];
        $this->assertEquals(count($this->adapter->requestsMade), 1);
    }

    /**
     * Pagination: the first of two requests for the next fetch.  Verify the url to get the next collection.
     */
    public function testShouldRequestCorrectCollectionPage() {
        $this->adapter->clearRequests();
        $subscriber = $this->found[1];
        $uri = $this->adapter->requestsMade[0]['uri'];
        $this->assertEquals($uri, '/accounts/1/lists/303449/subscribers?status=unsubscribed&ws.op=find&ws.size=1&ws.start=1');
    }

    /**
     * Pagination: the second of two requests for the next fetch.  Verify the url to get the total size of the next collection.
     */
    public function testShouldFetchCorrectDataOnSecondPage() {
        $this->adapter->clearRequests();
        $subscriber = $this->found[1];
        $this->assertEquals($subscriber->data['self_link'], 'https://api.aweber.com/1.0/accounts/1/lists/303449/subscribers/50205518');
    }
}


class TestAWeberCollection extends PHPUnit_Framework_TestCase {

    /**
     * Run before each test.  Sets up mock adapter, which uses fixture
     * data for requests, and creates a new collection.
     */
    public function setUp() {
        $this->adapter = get_mock_adapter();
        $this->url = '/accounts/1/lists';
        $data = $this->adapter->request('GET', $this->url);
        $this->collection = new AWeberCollection($data, $this->url, $this->adapter);
    }

    /**
     * Should have the total size available.
     */
    public function testShouldHaveTotalSize() {
        $this->assertEquals($this->collection->total_size, 24);
    }

    /**
     * Should have the URL used to generate this collection
     */
    public function testShouldHaveURL() {
        $this->assertEquals($this->collection->url, $this->url);
    }

    /**
     * Should not allow direct access to the entries data retreived from
     * the request.
     */
    public function testShouldNotAccessEntries() {
        $this->assertNull($this->collection->entries);
    }

    /**
     * Should allow entries to be accessed as an array
     */
    public function testShouldAccessEntiresAsArray() {
        $entry = $this->collection[0];
        $this->assertTrue(is_a($entry, 'AWeberResponse'));
        $this->assertTrue(is_a($entry, 'AWeberEntry'));
        $this->assertEquals($entry->id, 1701533);
    }

    public function testShouldKnowItsCollectionType() {
        $this->assertEquals($this->collection->type, 'lists');
    }

    /**
     * When accessing an offset out of range, should return null
     */
    public function testShouldNotAccessEntriesOutOfRange() {
        $this->assertNull($this->collection[26]);
    }

    /**
     * When accessing entries by offset, should only make a request when
     * accessing entries not in currenlty loaded pages.
     */
    public function testShouldLazilyLoadAdditionalPages() {
        $this->adapter->clearRequests();

        $this->assertEquals(sizeof($this->collection->data['entries']), 20);

        $entry = $this->collection[19];
        $this->assertEquals($entry->id, 1424745);
        $this->assertTrue(empty($this->adapter->requestsMade));

        $entry = $this->collection[20];
        $this->assertEquals($entry->id, 1364473);
        $this->assertEquals(count($this->adapter->requestsMade), 1);

        $entry = $this->collection[21];
        $this->assertEquals($entry->id, 1211626);
        $this->assertEquals(count($this->adapter->requestsMade), 1);
    }

    /**
     * Should implement the Iterator interface
     */
    public function testShouldBeAnIterator() {
        $this->assertTrue(is_a($this->collection, 'Iterator'));
    }

    /**
     * When accessed as an iterator, should return entries by offset,
     * from 0 to n-1.
     */
    public function testShouldAllowIteration() {
        $count = 0;
        foreach ($this->collection as $index => $entry) {
            $this->assertEquals($index, $count);
            $count++;
        }
        $this->assertEquals($count, $this->collection->total_size);
    }

    /**
     * getById - should return an AWeberEntry with the given id
     */
    public function testShouldAllowGetById() {
        $id = 303449;
        $name = 'default303449';
        $this->adapter->clearRequests();
        $entry = $this->collection->getById($id);

        $this->assertEquals($entry->id, $id);
        $this->assertEquals($entry->name, $name);
        $this->assertTrue(is_a($entry, 'AWeberEntry'));
        $this->assertEquals(count($this->adapter->requestsMade), 1);


        $this->assertEquals($this->adapter->requestsMade[0]['uri'],
            '/accounts/1/lists/303449');
    }

    /**
     * Should implement the countable interface, allowing count() and sizeOf()
     * functions to work properly
     */
    public function testShouldAllowCountOperations() {
        $this->assertEquals(count($this->collection), $this->collection->total_size);
        $this->assertEquals(sizeOf($this->collection), $this->collection->total_size);
    }

}

Spamworldpro Mini