@ -13,463 +13,464 @@ use JKingWeb\Arsse\Misc\Date;
use Phake;
use Phake;
trait SeriesArticle {
trait SeriesArticle {
protected $data = [
protected function setUpSeriesArticle() {
'arsse_users' => [
$this->data = [
'columns' => [
'arsse_users' => [
'id' => 'str',
'columns' => [
'password' => 'str',
'id' => 'str',
'name' => 'str',
'password' => 'str',
'name' => 'str',
],
'rows' => [
["jane.doe@example.com", "", "Jane Doe"],
["john.doe@example.com", "", "John Doe"],
["john.doe@example.org", "", "John Doe"],
["john.doe@example.net", "", "John Doe"],
],
],
],
'rows' => [
'arsse_folders' => [
["jane.doe@example.com", "", "Jane Doe"],
'columns' => [
["john.doe@example.com", "", "John Doe"],
'id' => "int",
["john.doe@example.org", "", "John Doe"],
'owner' => "str",
["john.doe@example.net", "", "John Doe"],
'parent' => "int",
'name' => "str",
],
'rows' => [
[1, "john.doe@example.com", null, "Technology"],
[2, "john.doe@example.com", 1, "Software"],
[3, "john.doe@example.com", 1, "Rocketry"],
[4, "jane.doe@example.com", null, "Politics"],
[5, "john.doe@example.com", null, "Politics"],
[6, "john.doe@example.com", 2, "Politics"],
[7, "john.doe@example.net", null, "Technology"],
[8, "john.doe@example.net", 7, "Software"],
[9, "john.doe@example.net", null, "Politics"],
]
],
],
],
'arsse_feeds' => [
'arsse_folders' => [
'columns' => [
'columns' => [
'id' => "int",
'id' => "int",
'url' => "str",
'owner' => "str",
'title' => "str",
'parent' => "int",
],
'name' => "str",
'rows' => [
[1,"http://example.com/1", "Feed 1"],
[2,"http://example.com/2", "Feed 2"],
[3,"http://example.com/3", "Feed 3"],
[4,"http://example.com/4", "Feed 4"],
[5,"http://example.com/5", "Feed 5"],
[6,"http://example.com/6", "Feed 6"],
[7,"http://example.com/7", "Feed 7"],
[8,"http://example.com/8", "Feed 8"],
[9,"http://example.com/9", "Feed 9"],
[10,"http://example.com/10", "Feed 10"],
[11,"http://example.com/11", "Feed 11"],
[12,"http://example.com/12", "Feed 12"],
[13,"http://example.com/13", "Feed 13"],
]
],
],
'rows' => [
'arsse_subscriptions' => [
[1, "john.doe@example.com", null, "Technology"],
'columns' => [
[2, "john.doe@example.com", 1, "Software"],
'id' => "int",
[3, "john.doe@example.com", 1, "Rocketry"],
'owner' => "str",
[4, "jane.doe@example.com", null, "Politics"],
'feed' => "int",
[5, "john.doe@example.com", null, "Politics"],
'folder' => "int",
[6, "john.doe@example.com", 2, "Politics"],
'title' => "str",
[7, "john.doe@example.net", null, "Technology"],
],
[8, "john.doe@example.net", 7, "Software"],
'rows' => [
[9, "john.doe@example.net", null, "Politics"],
[1, "john.doe@example.com",1, null,"Subscription 1"],
]
[2, "john.doe@example.com",2, null,null],
],
[3, "john.doe@example.com",3, 1,"Subscription 3"],
'arsse_feeds' => [
[4, "john.doe@example.com",4, 6,null],
'columns' => [
[5, "john.doe@example.com",10, 5,"Subscription 5"],
'id' => "int",
[6, "jane.doe@example.com",1, null,null],
'url' => "str",
[7, "jane.doe@example.com",10,null,"Subscription 7"],
'title' => "str",
[8, "john.doe@example.org",11,null,null],
[9, "john.doe@example.org",12,null,"Subscription 9"],
[10,"john.doe@example.org",13,null,null],
[11,"john.doe@example.net",10,null,"Subscription 11"],
[12,"john.doe@example.net",2, 9,null],
[13,"john.doe@example.net",3, 8,"Subscription 13"],
[14,"john.doe@example.net",4, 7,null],
]
],
],
'rows' => [
'arsse_articles' => [
[1,"http://example.com/1", "Feed 1"],
'columns' => [
[2,"http://example.com/2", "Feed 2"],
'id' => "int",
[3,"http://example.com/3", "Feed 3"],
'feed' => "int",
[4,"http://example.com/4", "Feed 4"],
'url' => "str",
[5,"http://example.com/5", "Feed 5"],
'title' => "str",
[6,"http://example.com/6", "Feed 6"],
'author' => "str",
[7,"http://example.com/7", "Feed 7"],
'published' => "datetime",
[8,"http://example.com/8", "Feed 8"],
'edited' => "datetime",
[9,"http://example.com/9", "Feed 9"],
'content' => "str",
[10,"http://example.com/10", "Feed 10"],
'guid' => "str",
[11,"http://example.com/11", "Feed 11"],
'url_title_hash' => "str",
[12,"http://example.com/12", "Feed 12"],
'url_content_hash' => "str",
[13,"http://example.com/13", "Feed 13"],
'title_content_hash' => "str",
]
'modified' => "datetime",
],
],
'arsse_subscriptions' => [
'rows' => [
'columns' => [
[1,1,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'id' => "int",
[2,1,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
'owner' => "str",
[3,2,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'feed' => "int",
[4,2,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
'folder' => "int",
[5,3,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'title' => "str",
[6,3,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[7,4,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[8,4,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[9,5,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[10,5,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[11,6,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[12,6,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[13,7,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[14,7,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[15,8,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[16,8,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[17,9,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[18,9,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[19,10,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[20,10,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[101,11,'http://example.com/1','Article title 1','','2000-01-01 00:00:00','2000-01-01 00:00:01','< p > Article content 1< / p > ','e433653cef2e572eee4215fa299a4a5af9137b2cefd6283c85bd69a32915beda','f5cb8bfc1c7396dc9816af212a3e2ac5221585c2a00bf7ccb6aabd95dcfcd6a6','fb0bc8f8cb08913dc5a497db700e327f1d34e4987402687d494a5891f24714d4','18fdd4fa93d693128c43b004399e5c9cea6c261ddfa002518d3669f55d8c2207','2000-01-01 01:00:00'],
[102,11,'http://example.com/2','Article title 2','','2000-01-02 00:00:00','2000-01-02 00:00:02','< p > Article content 2< / p > ','5be8a5a46ecd52ed132191c8d27fb1af6b3d4edc00234c5d9f8f0e10562ed3b7','0e86d2de822a174fe3c44a466953e63ca1f1a58a19cbf475fce0855d4e3d5153','13075894189c47ffcfafd1dfe7fbb539f7c74a69d35a399b3abf8518952714f9','2abd0a8cba83b8214a66c8f0293ba63e467d720540e29ff8ddcdab069d4f1c9e','2000-01-02 02:00:00'],
[103,12,'http://example.com/3','Article title 3','','2000-01-03 00:00:00','2000-01-03 00:00:03','< p > Article content 3< / p > ','31a6594500a48b59fcc8a075ce82b946c9c3c782460d088bd7b8ef3ede97ad92','f74b06b240bd08abf4d3fdfc20dba6a6f6eb8b4f1a00e9a617efd63a87180a4b','b278380e984cefe63f0e412b88ffc9cb0befdfa06fdc00bace1da99a8daff406','ad622b31e739cd3a3f3c788991082cf4d2f7a8773773008e75f0572e58cd373b','2000-01-03 03:00:00'],
[104,12,'http://example.com/4','Article title 4','','2000-01-04 00:00:00','2000-01-04 00:00:04','< p > Article content 4< / p > ','804e517d623390e71497982c77cf6823180342ebcd2e7d5e32da1e55b09dd180','f3615c7f16336d3ea242d35cf3fc17dbc4ee3afb78376bf49da2dd7a5a25dec8','f11c2b4046f207579aeb9c69a8c20ca5461cef49756ccfa5ba5e2344266da3b3','ab2da63276acce431250b18d3d49b988b226a99c7faadf275c90b751aee05be9','2000-01-04 04:00:00'],
[105,13,'http://example.com/5','Article title 5','','2000-01-05 00:00:00','2000-01-05 00:00:05','< p > Article content 5< / p > ','db3e736c2c492f5def5c5da33ddcbea1824040e9ced2142069276b0a6e291a41','d40da96e39eea6c55948ccbe9b3d275b5f931298288dbe953990c5f496097022','834240f84501b5341d375414718204ec421561f3825d34c22bf9182203e42900','43b970ac6ec5f8a9647b2c7e4eed8b1d7f62e154a95eed748b0294c1256764ba','2000-01-05 05:00:00'],
]
],
],
'rows' => [
'arsse_enclosures' => [
[1, "john.doe@example.com",1, null,"Subscription 1"],
'columns' => [
[2, "john.doe@example.com",2, null,null],
'article' => "int",
[3, "john.doe@example.com",3, 1,"Subscription 3"],
'url' => "str",
[4, "john.doe@example.com",4, 6,null],
'type' => "str",
[5, "john.doe@example.com",10, 5,"Subscription 5"],
],
[6, "jane.doe@example.com",1, null,null],
'rows' => [
[7, "jane.doe@example.com",10,null,"Subscription 7"],
[102,"http://example.com/text","text/plain"],
[8, "john.doe@example.org",11,null,null],
[103,"http://example.com/video","video/webm"],
[9, "john.doe@example.org",12,null,"Subscription 9"],
[104,"http://example.com/image","image/svg+xml"],
[10,"john.doe@example.org",13,null,null],
[105,"http://example.com/audio","audio/ogg"],
[11,"john.doe@example.net",10,null,"Subscription 11"],
[12,"john.doe@example.net",2, 9,null],
]
[13,"john.doe@example.net",3, 8,"Subscription 13"],
[14,"john.doe@example.net",4, 7,null],
]
],
'arsse_articles' => [
'columns' => [
'id' => "int",
'feed' => "int",
'url' => "str",
'title' => "str",
'author' => "str",
'published' => "datetime",
'edited' => "datetime",
'content' => "str",
'guid' => "str",
'url_title_hash' => "str",
'url_content_hash' => "str",
'title_content_hash' => "str",
'modified' => "datetime",
],
],
'rows' => [
'arsse_editions' => [
[1,1,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'columns' => [
[2,1,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
'id' => "int",
[3,2,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'article' => "int",
[4,2,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
],
[5,3,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
'rows' => [
[6,3,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[1,1],
[7,4,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[2,2],
[8,4,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[3,3],
[9,5,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[4,4],
[10,5,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[5,5],
[11,6,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[6,6],
[12,6,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[7,7],
[13,7,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[8,8],
[14,7,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[9,9],
[15,8,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[10,10],
[16,8,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[11,11],
[17,9,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[12,12],
[18,9,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[13,13],
[19,10,null,null,null,null,null,null,null,"","","","2000-01-01T00:00:00Z"],
[14,14],
[20,10,null,null,null,null,null,null,null,"","","","2010-01-01T00:00:00Z"],
[15,15],
[101,11,'http://example.com/1','Article title 1','','2000-01-01 00:00:00','2000-01-01 00:00:01','< p > Article content 1< / p > ','e433653cef2e572eee4215fa299a4a5af9137b2cefd6283c85bd69a32915beda','f5cb8bfc1c7396dc9816af212a3e2ac5221585c2a00bf7ccb6aabd95dcfcd6a6','fb0bc8f8cb08913dc5a497db700e327f1d34e4987402687d494a5891f24714d4','18fdd4fa93d693128c43b004399e5c9cea6c261ddfa002518d3669f55d8c2207','2000-01-01 01:00:00'],
[16,16],
[102,11,'http://example.com/2','Article title 2','','2000-01-02 00:00:00','2000-01-02 00:00:02','< p > Article content 2< / p > ','5be8a5a46ecd52ed132191c8d27fb1af6b3d4edc00234c5d9f8f0e10562ed3b7','0e86d2de822a174fe3c44a466953e63ca1f1a58a19cbf475fce0855d4e3d5153','13075894189c47ffcfafd1dfe7fbb539f7c74a69d35a399b3abf8518952714f9','2abd0a8cba83b8214a66c8f0293ba63e467d720540e29ff8ddcdab069d4f1c9e','2000-01-02 02:00:00'],
[17,17],
[103,12,'http://example.com/3','Article title 3','','2000-01-03 00:00:00','2000-01-03 00:00:03','< p > Article content 3< / p > ','31a6594500a48b59fcc8a075ce82b946c9c3c782460d088bd7b8ef3ede97ad92','f74b06b240bd08abf4d3fdfc20dba6a6f6eb8b4f1a00e9a617efd63a87180a4b','b278380e984cefe63f0e412b88ffc9cb0befdfa06fdc00bace1da99a8daff406','ad622b31e739cd3a3f3c788991082cf4d2f7a8773773008e75f0572e58cd373b','2000-01-03 03:00:00'],
[18,18],
[104,12,'http://example.com/4','Article title 4','','2000-01-04 00:00:00','2000-01-04 00:00:04','< p > Article content 4< / p > ','804e517d623390e71497982c77cf6823180342ebcd2e7d5e32da1e55b09dd180','f3615c7f16336d3ea242d35cf3fc17dbc4ee3afb78376bf49da2dd7a5a25dec8','f11c2b4046f207579aeb9c69a8c20ca5461cef49756ccfa5ba5e2344266da3b3','ab2da63276acce431250b18d3d49b988b226a99c7faadf275c90b751aee05be9','2000-01-04 04:00:00'],
[19,19],
[105,13,'http://example.com/5','Article title 5','','2000-01-05 00:00:00','2000-01-05 00:00:05','< p > Article content 5< / p > ','db3e736c2c492f5def5c5da33ddcbea1824040e9ced2142069276b0a6e291a41','d40da96e39eea6c55948ccbe9b3d275b5f931298288dbe953990c5f496097022','834240f84501b5341d375414718204ec421561f3825d34c22bf9182203e42900','43b970ac6ec5f8a9647b2c7e4eed8b1d7f62e154a95eed748b0294c1256764ba','2000-01-05 05:00:00'],
[20,20],
]
[101,101],
],
[102,102],
'arsse_enclosures' => [
[103,103],
'columns' => [
[104,104],
'article' => "int",
[105,105],
'url' => "str",
[202,102],
'type' => "str",
[203,103],
[204,104],
[205,105],
[305,105],
[1001,20],
]
],
],
'rows' => [
'arsse_marks' => [
[102,"http://example.com/text","text/plain"],
'columns' => [
[103,"http://example.com/video","video/webm"],
'subscription' => "int",
[104,"http://example.com/image","image/svg+xml"],
'article' => "int",
[105,"http://example.com/audio","audio/ogg"],
'read' => "bool",
'starred' => "bool",
]
'modified' => "datetime",
],
'note' => "str",
'arsse_editions' => [
],
'columns' => [
'rows' => [
'id' => "int",
[1, 1,1,1,'2000-01-01 00:00:00',''],
'article' => "int",
[5, 19,1,0,'2016-01-01 00:00:00',''],
[5, 20,0,1,'2005-01-01 00:00:00',''],
[7, 20,1,0,'2010-01-01 00:00:00',''],
[8, 102,1,0,'2000-01-02 02:00:00','Note 2'],
[9, 103,0,1,'2000-01-03 03:00:00','Note 3'],
[9, 104,1,1,'2000-01-04 04:00:00','Note 4'],
[10,105,0,0,'2000-01-05 05:00:00',''],
[11, 19,0,0,'2017-01-01 00:00:00','ook'],
[11, 20,1,0,'2017-01-01 00:00:00','eek'],
[12, 3,0,1,'2017-01-01 00:00:00','ack'],
[12, 4,1,1,'2017-01-01 00:00:00','ach'],
[1, 2,0,0,'2010-01-01 00:00:00','Some Note'],
]
],
],
'rows' => [
'arsse_categories' => [ // author-supplied categories
[1,1],
'columns' => [
[2,2],
'article' => "int",
[3,3],
'name' => "str",
[4,4],
],
[5,5],
'rows' => [
[6,6],
[19,"Fascinating"],
[7,7],
[19,"Logical"],
[8,8],
[20,"Interesting"],
[9,9],
[20,"Logical"],
[10,10],
],
[11,11],
[12,12],
[13,13],
[14,14],
[15,15],
[16,16],
[17,17],
[18,18],
[19,19],
[20,20],
[101,101],
[102,102],
[103,103],
[104,104],
[105,105],
[202,102],
[203,103],
[204,104],
[205,105],
[305,105],
[1001,20],
]
],
'arsse_marks' => [
'columns' => [
'subscription' => "int",
'article' => "int",
'read' => "bool",
'starred' => "bool",
'modified' => "datetime",
'note' => "str",
],
],
'rows' => [
'arsse_labels' => [
[1, 1,1,1,'2000-01-01 00:00:00',''],
'columns' => [
[5, 19,1,0,'2016-01-01 00:00:00',''],
'id' => "int",
[5, 20,0,1,'2005-01-01 00:00:00',''],
'owner' => "str",
[7, 20,1,0,'2010-01-01 00:00:00',''],
'name' => "str",
[8, 102,1,0,'2000-01-02 02:00:00','Note 2'],
],
[9, 103,0,1,'2000-01-03 03:00:00','Note 3'],
'rows' => [
[9, 104,1,1,'2000-01-04 04:00:00','Note 4'],
[1,"john.doe@example.com","Interesting"],
[10,105,0,0,'2000-01-05 05:00:00',''],
[2,"john.doe@example.com","Fascinating"],
[11, 19,0,0,'2017-01-01 00:00:00','ook'],
[3,"jane.doe@example.com","Boring"],
[11, 20,1,0,'2017-01-01 00:00:00','eek'],
[4,"john.doe@example.com","Lonely"],
[12, 3,0,1,'2017-01-01 00:00:00','ack'],
],
[12, 4,1,1,'2017-01-01 00:00:00','ach'],
[1, 2,0,0,'2010-01-01 00:00:00','Some Note'],
]
],
'arsse_categories' => [ // author-supplied categories
'columns' => [
'article' => "int",
'name' => "str",
],
],
'rows' => [
'arsse_label_members' => [
[19,"Fascinating"],
'columns' => [
[19,"Logical"],
'label' => "int",
[20,"Interesting"],
'article' => "int",
[20,"Logical"],
'subscription' => "int",
'assigned' => "bool",
'modified' => "datetime",
],
'rows' => [
[1, 1,1,1,'2000-01-01 00:00:00'],
[2, 1,1,1,'2000-01-01 00:00:00'],
[1,19,5,1,'2000-01-01 00:00:00'],
[2,20,5,1,'2000-01-01 00:00:00'],
[1, 5,3,0,'2000-01-01 00:00:00'],
[2, 5,3,1,'2000-01-01 00:00:00'],
[4, 7,4,0,'2000-01-01 00:00:00'],
[4, 8,4,1,'2015-01-01 00:00:00'],
],
],
],
],
];
'arsse_labels' => [
$this->matches = [
'columns' => [
[
'id' => "int",
'id' => 101,
'owner' => "str",
'url' => 'http://example.com/1',
'name' => "str",
'title' => 'Article title 1',
'subscription_title' => "Feed 11",
'author' => '',
'content' => '< p > Article content 1< / p > ',
'guid' => 'e433653cef2e572eee4215fa299a4a5af9137b2cefd6283c85bd69a32915beda',
'published_date' => '2000-01-01 00:00:00',
'edited_date' => '2000-01-01 00:00:01',
'modified_date' => '2000-01-01 01:00:00',
'unread' => 1,
'starred' => 0,
'edition' => 101,
'subscription' => 8,
'fingerprint' => 'f5cb8bfc1c7396dc9816af212a3e2ac5221585c2a00bf7ccb6aabd95dcfcd6a6:fb0bc8f8cb08913dc5a497db700e327f1d34e4987402687d494a5891f24714d4:18fdd4fa93d693128c43b004399e5c9cea6c261ddfa002518d3669f55d8c2207',
'media_url' => null,
'media_type' => null,
'note' => "",
],
],
'rows' => [
[
[1,"john.doe@example.com","Interesting"],
'id' => 102,
[2,"john.doe@example.com","Fascinating"],
'url' => 'http://example.com/2',
[3,"jane.doe@example.com","Boring"],
'title' => 'Article title 2',
[4,"john.doe@example.com","Lonely"],
'subscription_title' => "Feed 11",
'author' => '',
'content' => '< p > Article content 2< / p > ',
'guid' => '5be8a5a46ecd52ed132191c8d27fb1af6b3d4edc00234c5d9f8f0e10562ed3b7',
'published_date' => '2000-01-02 00:00:00',
'edited_date' => '2000-01-02 00:00:02',
'modified_date' => '2000-01-02 02:00:00',
'unread' => 0,
'starred' => 0,
'edition' => 202,
'subscription' => 8,
'fingerprint' => '0e86d2de822a174fe3c44a466953e63ca1f1a58a19cbf475fce0855d4e3d5153:13075894189c47ffcfafd1dfe7fbb539f7c74a69d35a399b3abf8518952714f9:2abd0a8cba83b8214a66c8f0293ba63e467d720540e29ff8ddcdab069d4f1c9e',
'media_url' => "http://example.com/text",
'media_type' => "text/plain",
'note' => "Note 2",
],
],
],
[
'arsse_label_members' => [
'id' => 103,
'columns' => [
'url' => 'http://example.com/3',
'label' => "int",
'title' => 'Article title 3',
'article' => "int",
'subscription_title' => "Subscription 9",
'subscription' => "int",
'author' => '',
'assigned' => "bool",
'content' => '< p > Article content 3< / p > ',
'modified' => "datetime",
'guid' => '31a6594500a48b59fcc8a075ce82b946c9c3c782460d088bd7b8ef3ede97ad92',
'published_date' => '2000-01-03 00:00:00',
'edited_date' => '2000-01-03 00:00:03',
'modified_date' => '2000-01-03 03:00:00',
'unread' => 1,
'starred' => 1,
'edition' => 203,
'subscription' => 9,
'fingerprint' => 'f74b06b240bd08abf4d3fdfc20dba6a6f6eb8b4f1a00e9a617efd63a87180a4b:b278380e984cefe63f0e412b88ffc9cb0befdfa06fdc00bace1da99a8daff406:ad622b31e739cd3a3f3c788991082cf4d2f7a8773773008e75f0572e58cd373b',
'media_url' => "http://example.com/video",
'media_type' => "video/webm",
'note' => "Note 3",
],
],
'rows' => [
[
[1, 1,1,1,'2000-01-01 00:00:00'],
'id' => 104,
[2, 1,1,1,'2000-01-01 00:00:00'],
'url' => 'http://example.com/4',
[1,19,5,1,'2000-01-01 00:00:00'],
'title' => 'Article title 4',
[2,20,5,1,'2000-01-01 00:00:00'],
'subscription_title' => "Subscription 9",
[1, 5,3,0,'2000-01-01 00:00:00'],
'author' => '',
[2, 5,3,1,'2000-01-01 00:00:00'],
'content' => '< p > Article content 4< / p > ',
[4, 7,4,0,'2000-01-01 00:00:00'],
'guid' => '804e517d623390e71497982c77cf6823180342ebcd2e7d5e32da1e55b09dd180',
[4, 8,4,1,'2015-01-01 00:00:00'],
'published_date' => '2000-01-04 00:00:00',
'edited_date' => '2000-01-04 00:00:04',
'modified_date' => '2000-01-04 04:00:00',
'unread' => 0,
'starred' => 1,
'edition' => 204,
'subscription' => 9,
'fingerprint' => 'f3615c7f16336d3ea242d35cf3fc17dbc4ee3afb78376bf49da2dd7a5a25dec8:f11c2b4046f207579aeb9c69a8c20ca5461cef49756ccfa5ba5e2344266da3b3:ab2da63276acce431250b18d3d49b988b226a99c7faadf275c90b751aee05be9',
'media_url' => "http://example.com/image",
'media_type' => "image/svg+xml",
'note' => "Note 4",
],
],
],
[
];
'id' => 105,
protected $matches = [
'url' => 'http://example.com/5',
[
'title' => 'Article title 5',
'id' => 101,
'subscription_title' => "Feed 13",
'url' => 'http://example.com/1',
'author' => '',
'title' => 'Article title 1',
'content' => '< p > Article content 5< / p > ',
'subscription_title' => "Feed 11",
'guid' => 'db3e736c2c492f5def5c5da33ddcbea1824040e9ced2142069276b0a6e291a41',
'author' => '',
'published_date' => '2000-01-05 00:00:00',
'content' => '< p > Article content 1< / p > ',
'edited_date' => '2000-01-05 00:00:05',
'guid' => 'e433653cef2e572eee4215fa299a4a5af9137b2cefd6283c85bd69a32915beda',
'modified_date' => '2000-01-05 05:00:00',
'published_date' => '2000-01-01 00:00:00',
'unread' => 1,
'edited_date' => '2000-01-01 00:00:01',
'starred' => 0,
'modified_date' => '2000-01-01 01:00:00',
'edition' => 305,
'unread' => 1,
'subscription' => 10,
'starred' => 0,
'fingerprint' => 'd40da96e39eea6c55948ccbe9b3d275b5f931298288dbe953990c5f496097022:834240f84501b5341d375414718204ec421561f3825d34c22bf9182203e42900:43b970ac6ec5f8a9647b2c7e4eed8b1d7f62e154a95eed748b0294c1256764ba',
'edition' => 101,
'media_url' => "http://example.com/audio",
'subscription' => 8,
'media_type' => "audio/ogg",
'fingerprint' => 'f5cb8bfc1c7396dc9816af212a3e2ac5221585c2a00bf7ccb6aabd95dcfcd6a6:fb0bc8f8cb08913dc5a497db700e327f1d34e4987402687d494a5891f24714d4:18fdd4fa93d693128c43b004399e5c9cea6c261ddfa002518d3669f55d8c2207',
'note' => "",
'media_url' => null,
],
'media_type' => null,
];
'note' => "",
$this->fields = [
],
Database::LIST_MINIMAL => [
[
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
'id' => 102,
],
'url' => 'http://example.com/2',
Database::LIST_CONSERVATIVE => [
'title' => 'Article title 2',
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
'subscription_title' => "Feed 11",
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
'author' => '',
],
'content' => '< p > Article content 2< / p > ',
Database::LIST_TYPICAL => [
'guid' => '5be8a5a46ecd52ed132191c8d27fb1af6b3d4edc00234c5d9f8f0e10562ed3b7',
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
'published_date' => '2000-01-02 00:00:00',
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
'edited_date' => '2000-01-02 00:00:02',
"content", "media_url", "media_type",
'modified_date' => '2000-01-02 02:00:00',
],
'unread' => 0,
Database::LIST_FULL => [
'starred' => 0,
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
'edition' => 202,
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
'subscription' => 8,
"content", "media_url", "media_type",
'fingerprint' => '0e86d2de822a174fe3c44a466953e63ca1f1a58a19cbf475fce0855d4e3d5153:13075894189c47ffcfafd1dfe7fbb539f7c74a69d35a399b3abf8518952714f9:2abd0a8cba83b8214a66c8f0293ba63e467d720540e29ff8ddcdab069d4f1c9e',
"note",
'media_url' => "http://example.com/text",
],
'media_type' => "text/plain",
];
'note' => "Note 2",
],
[
'id' => 103,
'url' => 'http://example.com/3',
'title' => 'Article title 3',
'subscription_title' => "Subscription 9",
'author' => '',
'content' => '< p > Article content 3< / p > ',
'guid' => '31a6594500a48b59fcc8a075ce82b946c9c3c782460d088bd7b8ef3ede97ad92',
'published_date' => '2000-01-03 00:00:00',
'edited_date' => '2000-01-03 00:00:03',
'modified_date' => '2000-01-03 03:00:00',
'unread' => 1,
'starred' => 1,
'edition' => 203,
'subscription' => 9,
'fingerprint' => 'f74b06b240bd08abf4d3fdfc20dba6a6f6eb8b4f1a00e9a617efd63a87180a4b:b278380e984cefe63f0e412b88ffc9cb0befdfa06fdc00bace1da99a8daff406:ad622b31e739cd3a3f3c788991082cf4d2f7a8773773008e75f0572e58cd373b',
'media_url' => "http://example.com/video",
'media_type' => "video/webm",
'note' => "Note 3",
],
[
'id' => 104,
'url' => 'http://example.com/4',
'title' => 'Article title 4',
'subscription_title' => "Subscription 9",
'author' => '',
'content' => '< p > Article content 4< / p > ',
'guid' => '804e517d623390e71497982c77cf6823180342ebcd2e7d5e32da1e55b09dd180',
'published_date' => '2000-01-04 00:00:00',
'edited_date' => '2000-01-04 00:00:04',
'modified_date' => '2000-01-04 04:00:00',
'unread' => 0,
'starred' => 1,
'edition' => 204,
'subscription' => 9,
'fingerprint' => 'f3615c7f16336d3ea242d35cf3fc17dbc4ee3afb78376bf49da2dd7a5a25dec8:f11c2b4046f207579aeb9c69a8c20ca5461cef49756ccfa5ba5e2344266da3b3:ab2da63276acce431250b18d3d49b988b226a99c7faadf275c90b751aee05be9',
'media_url' => "http://example.com/image",
'media_type' => "image/svg+xml",
'note' => "Note 4",
],
[
'id' => 105,
'url' => 'http://example.com/5',
'title' => 'Article title 5',
'subscription_title' => "Feed 13",
'author' => '',
'content' => '< p > Article content 5< / p > ',
'guid' => 'db3e736c2c492f5def5c5da33ddcbea1824040e9ced2142069276b0a6e291a41',
'published_date' => '2000-01-05 00:00:00',
'edited_date' => '2000-01-05 00:00:05',
'modified_date' => '2000-01-05 05:00:00',
'unread' => 1,
'starred' => 0,
'edition' => 305,
'subscription' => 10,
'fingerprint' => 'd40da96e39eea6c55948ccbe9b3d275b5f931298288dbe953990c5f496097022:834240f84501b5341d375414718204ec421561f3825d34c22bf9182203e42900:43b970ac6ec5f8a9647b2c7e4eed8b1d7f62e154a95eed748b0294c1256764ba',
'media_url' => "http://example.com/audio",
'media_type' => "audio/ogg",
'note' => "",
],
];
protected $fields = [
Database::LIST_MINIMAL => [
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
],
Database::LIST_CONSERVATIVE => [
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
],
Database::LIST_TYPICAL => [
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
"content", "media_url", "media_type",
],
Database::LIST_FULL => [
"id", "subscription", "feed", "modified_date", "marked_date", "unread", "starred", "edition", "edited_date",
"url", "title", "subscription_title", "author", "guid", "published_date", "fingerprint",
"content", "media_url", "media_type",
"note",
],
];
public function setUpSeries() {
$this->checkTables = ['arsse_marks' => ["subscription","article","read","starred","modified","note"],];
$this->checkTables = ['arsse_marks' => ["subscription","article","read","starred","modified","note"],];
$this->user = "john.doe@example.net";
$this->user = "john.doe@example.net";
}
}
protected function compareIds(array $exp, Context $c) {
protected function tearDownSeriesArticle() {
$ids = array_column($ids = Arsse::$db->articleList($this->user, $c)->getAll(), "id");
unset($this->data, $this->matches, $this->fields, $this->checkTables, $this->user);
sort($ids);
sort($exp);
$this->assertEquals($exp, $ids);
}
}
public function testListArticlesCheckingContext() {
public function testListArticlesCheckingContext() {
$this->user = "john.doe@example.com";
$compareIds = function(array $exp, Context $c) {
$ids = array_column($ids = Arsse::$db->articleList("john.doe@example.com", $c)->getAll(), "id");
sort($ids);
sort($exp);
$this->assertEquals($exp, $ids);
};
// get all items for user
// get all items for user
$exp = [1,2,3,4,5,6,7,8,19,20];
$exp = [1,2,3,4,5,6,7,8,19,20];
$this->compareIds($exp, new Context);
$compareIds($exp, new Context);
$this->compareIds($exp, (new Context)->articles(range(1, Database::LIMIT_ARTICLES * 3)));
$compareIds($exp, (new Context)->articles(range(1, Database::LIMIT_ARTICLES * 3)));
// get items from a folder tree
// get items from a folder tree
$this-> compareIds([5,6,7,8], (new Context)->folder(1));
$compareIds([5,6,7,8], (new Context)->folder(1));
// get items from a leaf folder
// get items from a leaf folder
$this-> compareIds([7,8], (new Context)->folder(6));
$compareIds([7,8], (new Context)->folder(6));
// get items from a non-leaf folder without descending
// get items from a non-leaf folder without descending
$this-> compareIds([1,2,3,4], (new Context)->folderShallow(0));
$compareIds([1,2,3,4], (new Context)->folderShallow(0));
$this-> compareIds([5,6], (new Context)->folderShallow(1));
$compareIds([5,6], (new Context)->folderShallow(1));
// get items from a single subscription
// get items from a single subscription
$exp = [19,20];
$exp = [19,20];
$this-> compareIds($exp, (new Context)->subscription(5));
$compareIds($exp, (new Context)->subscription(5));
// get un/read items from a single subscription
// get un/read items from a single subscription
$this-> compareIds([20], (new Context)->subscription(5)->unread(true));
$compareIds([20], (new Context)->subscription(5)->unread(true));
$this-> compareIds([19], (new Context)->subscription(5)->unread(false));
$compareIds([19], (new Context)->subscription(5)->unread(false));
// get starred articles
// get starred articles
$this-> compareIds([1,20], (new Context)->starred(true));
$compareIds([1,20], (new Context)->starred(true));
$this-> compareIds([2,3,4,5,6,7,8,19], (new Context)->starred(false));
$compareIds([2,3,4,5,6,7,8,19], (new Context)->starred(false));
$this-> compareIds([1], (new Context)->starred(true)->unread(false));
$compareIds([1], (new Context)->starred(true)->unread(false));
$this-> compareIds([], (new Context)->starred(true)->unread(false)->subscription(5));
$compareIds([], (new Context)->starred(true)->unread(false)->subscription(5));
// get items relative to edition
// get items relative to edition
$this-> compareIds([19], (new Context)->subscription(5)->latestEdition(999));
$compareIds([19], (new Context)->subscription(5)->latestEdition(999));
$this-> compareIds([19], (new Context)->subscription(5)->latestEdition(19));
$compareIds([19], (new Context)->subscription(5)->latestEdition(19));
$this-> compareIds([20], (new Context)->subscription(5)->oldestEdition(999));
$compareIds([20], (new Context)->subscription(5)->oldestEdition(999));
$this-> compareIds([20], (new Context)->subscription(5)->oldestEdition(1001));
$compareIds([20], (new Context)->subscription(5)->oldestEdition(1001));
// get items relative to article ID
// get items relative to article ID
$this-> compareIds([1,2,3], (new Context)->latestArticle(3));
$compareIds([1,2,3], (new Context)->latestArticle(3));
$this-> compareIds([19,20], (new Context)->oldestArticle(19));
$compareIds([19,20], (new Context)->oldestArticle(19));
// get items relative to (feed) modification date
// get items relative to (feed) modification date
$exp = [2,4,6,8,20];
$exp = [2,4,6,8,20];
$this-> compareIds($exp, (new Context)->modifiedSince("2005-01-01T00:00:00Z"));
$compareIds($exp, (new Context)->modifiedSince("2005-01-01T00:00:00Z"));
$this-> compareIds($exp, (new Context)->modifiedSince("2010-01-01T00:00:00Z"));
$compareIds($exp, (new Context)->modifiedSince("2010-01-01T00:00:00Z"));
$exp = [1,3,5,7,19];
$exp = [1,3,5,7,19];
$this-> compareIds($exp, (new Context)->notModifiedSince("2005-01-01T00:00:00Z"));
$compareIds($exp, (new Context)->notModifiedSince("2005-01-01T00:00:00Z"));
$this-> compareIds($exp, (new Context)->notModifiedSince("2000-01-01T00:00:00Z"));
$compareIds($exp, (new Context)->notModifiedSince("2000-01-01T00:00:00Z"));
// get items relative to (user) modification date (both marks and labels apply)
// get items relative to (user) modification date (both marks and labels apply)
$this-> compareIds([8,19], (new Context)->markedSince("2014-01-01T00:00:00Z"));
$compareIds([8,19], (new Context)->markedSince("2014-01-01T00:00:00Z"));
$this-> compareIds([2,4,6,8,19,20], (new Context)->markedSince("2010-01-01T00:00:00Z"));
$compareIds([2,4,6,8,19,20], (new Context)->markedSince("2010-01-01T00:00:00Z"));
$this-> compareIds([1,2,3,4,5,6,7,20], (new Context)->notMarkedSince("2014-01-01T00:00:00Z"));
$compareIds([1,2,3,4,5,6,7,20], (new Context)->notMarkedSince("2014-01-01T00:00:00Z"));
$this-> compareIds([1,3,5,7], (new Context)->notMarkedSince("2005-01-01T00:00:00Z"));
$compareIds([1,3,5,7], (new Context)->notMarkedSince("2005-01-01T00:00:00Z"));
// paged results
// paged results
$this-> compareIds([1], (new Context)->limit(1));
$compareIds([1], (new Context)->limit(1));
$this-> compareIds([2], (new Context)->limit(1)->oldestEdition(1+1));
$compareIds([2], (new Context)->limit(1)->oldestEdition(1+1));
$this-> compareIds([3], (new Context)->limit(1)->oldestEdition(2+1));
$compareIds([3], (new Context)->limit(1)->oldestEdition(2+1));
$this-> compareIds([4,5], (new Context)->limit(2)->oldestEdition(3+1));
$compareIds([4,5], (new Context)->limit(2)->oldestEdition(3+1));
// reversed results
// reversed results
$this-> compareIds([20], (new Context)->reverse(true)->limit(1));
$compareIds([20], (new Context)->reverse(true)->limit(1));
$this-> compareIds([19], (new Context)->reverse(true)->limit(1)->latestEdition(1001-1));
$compareIds([19], (new Context)->reverse(true)->limit(1)->latestEdition(1001-1));
$this-> compareIds([8], (new Context)->reverse(true)->limit(1)->latestEdition(19-1));
$compareIds([8], (new Context)->reverse(true)->limit(1)->latestEdition(19-1));
$this-> compareIds([7,6], (new Context)->reverse(true)->limit(2)->latestEdition(8-1));
$compareIds([7,6], (new Context)->reverse(true)->limit(2)->latestEdition(8-1));
// get articles by label ID
// get articles by label ID
$this-> compareIds([1,19], (new Context)->label(1));
$compareIds([1,19], (new Context)->label(1));
$this-> compareIds([1,5,20], (new Context)->label(2));
$compareIds([1,5,20], (new Context)->label(2));
// get articles by label name
// get articles by label name
$this-> compareIds([1,19], (new Context)->labelName("Interesting"));
$compareIds([1,19], (new Context)->labelName("Interesting"));
$this-> compareIds([1,5,20], (new Context)->labelName("Fascinating"));
$compareIds([1,5,20], (new Context)->labelName("Fascinating"));
// get articles with any or no label
// get articles with any or no label
$this-> compareIds([1,5,8,19,20], (new Context)->labelled(true));
$compareIds([1,5,8,19,20], (new Context)->labelled(true));
$this-> compareIds([2,3,4,6,7], (new Context)->labelled(false));
$compareIds([2,3,4,6,7], (new Context)->labelled(false));
// get a specific article or edition
// get a specific article or edition
$this-> compareIds([20], (new Context)->article(20));
$compareIds([20], (new Context)->article(20));
$this-> compareIds([20], (new Context)->edition(1001));
$compareIds([20], (new Context)->edition(1001));
// get multiple specific articles or editions
// get multiple specific articles or editions
$this-> compareIds([1,20], (new Context)->articles([1,20,50]));
$compareIds([1,20], (new Context)->articles([1,20,50]));
$this-> compareIds([1,20], (new Context)->editions([1,1001,50]));
$compareIds([1,20], (new Context)->editions([1,1001,50]));
// get articles base on whether or not they have notes
// get articles base on whether or not they have notes
$this-> compareIds([1,3,4,5,6,7,8,19,20], (new Context)->annotated(false));
$compareIds([1,3,4,5,6,7,8,19,20], (new Context)->annotated(false));
$this-> compareIds([2], (new Context)->annotated(true));
$compareIds([2], (new Context)->annotated(true));
// get specific starred articles
// get specific starred articles
$this-> compareIds([1], (new Context)->articles([1,2,3])->starred(true));
$compareIds([1], (new Context)->articles([1,2,3])->starred(true));
$this-> compareIds([2,3], (new Context)->articles([1,2,3])->starred(false));
$compareIds([2,3], (new Context)->articles([1,2,3])->starred(false));
}
}
public function testListArticlesOfAMissingFolder() {
public function testListArticlesOfAMissingFolder() {