diff options
Diffstat (limited to 'tests/Wallabag')
-rw-r--r-- | tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php | 101 | ||||
-rw-r--r-- | tests/Wallabag/CoreBundle/Controller/ExportControllerTest.php | 63 |
2 files changed, 113 insertions, 51 deletions
diff --git a/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php b/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php index 3a8f92e7..3dcc1cd0 100644 --- a/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php +++ b/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php | |||
@@ -90,19 +90,18 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
90 | public function testPostNewViaBookmarklet() | 90 | public function testPostNewViaBookmarklet() |
91 | { | 91 | { |
92 | $this->logInAs('admin'); | 92 | $this->logInAs('admin'); |
93 | $this->useTheme('baggy'); | ||
94 | $client = $this->getClient(); | 93 | $client = $this->getClient(); |
95 | 94 | ||
96 | $crawler = $client->request('GET', '/'); | 95 | $crawler = $client->request('GET', '/'); |
97 | 96 | ||
98 | $this->assertCount(4, $crawler->filter('div[class=entry]')); | 97 | $this->assertCount(4, $crawler->filter('li.entry')); |
99 | 98 | ||
100 | // Good URL | 99 | // Good URL |
101 | $client->request('GET', '/bookmarklet', ['url' => $this->url]); | 100 | $client->request('GET', '/bookmarklet', ['url' => $this->url]); |
102 | $this->assertSame(302, $client->getResponse()->getStatusCode()); | 101 | $this->assertSame(302, $client->getResponse()->getStatusCode()); |
103 | $client->followRedirect(); | 102 | $client->followRedirect(); |
104 | $crawler = $client->request('GET', '/'); | 103 | $crawler = $client->request('GET', '/'); |
105 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 104 | $this->assertCount(5, $crawler->filter('li.entry')); |
106 | 105 | ||
107 | $em = $client->getContainer() | 106 | $em = $client->getContainer() |
108 | ->get('doctrine.orm.entity_manager'); | 107 | ->get('doctrine.orm.entity_manager'); |
@@ -694,7 +693,6 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
694 | public function testFilterOnReadingTime() | 693 | public function testFilterOnReadingTime() |
695 | { | 694 | { |
696 | $this->logInAs('admin'); | 695 | $this->logInAs('admin'); |
697 | $this->useTheme('baggy'); | ||
698 | $client = $this->getClient(); | 696 | $client = $this->getClient(); |
699 | $entry = new Entry($this->getLoggedInUser()); | 697 | $entry = new Entry($this->getLoggedInUser()); |
700 | $entry->setUrl($this->url); | 698 | $entry->setUrl($this->url); |
@@ -713,7 +711,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
713 | 711 | ||
714 | $crawler = $client->submit($form, $data); | 712 | $crawler = $client->submit($form, $data); |
715 | 713 | ||
716 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 714 | $this->assertCount(1, $crawler->filter('li.entry')); |
717 | } | 715 | } |
718 | 716 | ||
719 | public function testFilterOnReadingTimeWithNegativeValue() | 717 | public function testFilterOnReadingTimeWithNegativeValue() |
@@ -733,17 +731,16 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
733 | $crawler = $client->submit($form, $data); | 731 | $crawler = $client->submit($form, $data); |
734 | 732 | ||
735 | // forcing negative value results in no entry displayed | 733 | // forcing negative value results in no entry displayed |
736 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 734 | $this->assertCount(0, $crawler->filter('li.entry')); |
737 | } | 735 | } |
738 | 736 | ||
739 | public function testFilterOnReadingTimeOnlyUpper() | 737 | public function testFilterOnReadingTimeOnlyUpper() |
740 | { | 738 | { |
741 | $this->logInAs('admin'); | 739 | $this->logInAs('admin'); |
742 | $this->useTheme('baggy'); | ||
743 | $client = $this->getClient(); | 740 | $client = $this->getClient(); |
744 | 741 | ||
745 | $crawler = $client->request('GET', '/all/list'); | 742 | $crawler = $client->request('GET', '/all/list'); |
746 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 743 | $this->assertCount(5, $crawler->filter('li.entry')); |
747 | 744 | ||
748 | $entry = new Entry($this->getLoggedInUser()); | 745 | $entry = new Entry($this->getLoggedInUser()); |
749 | $entry->setUrl($this->url); | 746 | $entry->setUrl($this->url); |
@@ -752,7 +749,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
752 | $this->getEntityManager()->flush(); | 749 | $this->getEntityManager()->flush(); |
753 | 750 | ||
754 | $crawler = $client->request('GET', '/all/list'); | 751 | $crawler = $client->request('GET', '/all/list'); |
755 | $this->assertCount(6, $crawler->filter('div[class=entry]')); | 752 | $this->assertCount(6, $crawler->filter('li.entry')); |
756 | 753 | ||
757 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 754 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
758 | 755 | ||
@@ -762,13 +759,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
762 | 759 | ||
763 | $crawler = $client->submit($form, $data); | 760 | $crawler = $client->submit($form, $data); |
764 | 761 | ||
765 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 762 | $this->assertCount(5, $crawler->filter('li.entry')); |
766 | } | 763 | } |
767 | 764 | ||
768 | public function testFilterOnReadingTimeOnlyLower() | 765 | public function testFilterOnReadingTimeOnlyLower() |
769 | { | 766 | { |
770 | $this->logInAs('admin'); | 767 | $this->logInAs('admin'); |
771 | $this->useTheme('baggy'); | ||
772 | $client = $this->getClient(); | 768 | $client = $this->getClient(); |
773 | 769 | ||
774 | $crawler = $client->request('GET', '/unread/list'); | 770 | $crawler = $client->request('GET', '/unread/list'); |
@@ -781,7 +777,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
781 | 777 | ||
782 | $crawler = $client->submit($form, $data); | 778 | $crawler = $client->submit($form, $data); |
783 | 779 | ||
784 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 780 | $this->assertCount(0, $crawler->filter('li.entry')); |
785 | 781 | ||
786 | $entry = new Entry($this->getLoggedInUser()); | 782 | $entry = new Entry($this->getLoggedInUser()); |
787 | $entry->setUrl($this->url); | 783 | $entry->setUrl($this->url); |
@@ -790,13 +786,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
790 | $this->getEntityManager()->flush(); | 786 | $this->getEntityManager()->flush(); |
791 | 787 | ||
792 | $crawler = $client->submit($form, $data); | 788 | $crawler = $client->submit($form, $data); |
793 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 789 | $this->assertCount(1, $crawler->filter('li.entry')); |
794 | } | 790 | } |
795 | 791 | ||
796 | public function testFilterOnUnreadStatus() | 792 | public function testFilterOnUnreadStatus() |
797 | { | 793 | { |
798 | $this->logInAs('admin'); | 794 | $this->logInAs('admin'); |
799 | $this->useTheme('baggy'); | ||
800 | $client = $this->getClient(); | 795 | $client = $this->getClient(); |
801 | 796 | ||
802 | $crawler = $client->request('GET', '/all/list'); | 797 | $crawler = $client->request('GET', '/all/list'); |
@@ -809,7 +804,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
809 | 804 | ||
810 | $crawler = $client->submit($form, $data); | 805 | $crawler = $client->submit($form, $data); |
811 | 806 | ||
812 | $this->assertCount(4, $crawler->filter('div[class=entry]')); | 807 | $this->assertCount(4, $crawler->filter('li.entry')); |
813 | 808 | ||
814 | $entry = new Entry($this->getLoggedInUser()); | 809 | $entry = new Entry($this->getLoggedInUser()); |
815 | $entry->setUrl($this->url); | 810 | $entry->setUrl($this->url); |
@@ -819,45 +814,56 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
819 | 814 | ||
820 | $crawler = $client->submit($form, $data); | 815 | $crawler = $client->submit($form, $data); |
821 | 816 | ||
822 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 817 | $this->assertCount(5, $crawler->filter('li.entry')); |
823 | } | 818 | } |
824 | 819 | ||
825 | public function testFilterOnCreationDate() | 820 | public function testFilterOnCreationDate() |
826 | { | 821 | { |
827 | $this->logInAs('admin'); | 822 | $this->logInAs('admin'); |
828 | $this->useTheme('baggy'); | ||
829 | $client = $this->getClient(); | 823 | $client = $this->getClient(); |
830 | 824 | ||
825 | $em = $this->getEntityManager(); | ||
826 | |||
827 | $today = new \DateTimeImmutable(); | ||
828 | $tomorrow = $today->add(new \DateInterval('P1D')); | ||
829 | $yesterday = $today->sub(new \DateInterval('P1D')); | ||
830 | |||
831 | $entry = new Entry($this->getLoggedInUser()); | ||
832 | $entry->setUrl('http://0.0.0.0/testFilterOnCreationDate'); | ||
833 | $entry->setCreatedAt($yesterday); | ||
834 | $em->persist($entry); | ||
835 | $em->flush(); | ||
836 | |||
831 | $crawler = $client->request('GET', '/unread/list'); | 837 | $crawler = $client->request('GET', '/unread/list'); |
832 | 838 | ||
833 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 839 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
834 | 840 | ||
835 | $data = [ | 841 | $data = [ |
836 | 'entry_filter[createdAt][left_date]' => date('d/m/Y'), | 842 | 'entry_filter[createdAt][left_date]' => $today->format('Y-m-d'), |
837 | 'entry_filter[createdAt][right_date]' => date('d/m/Y', strtotime('+1 day')), | 843 | 'entry_filter[createdAt][right_date]' => $tomorrow->format('Y-m-d'), |
838 | ]; | 844 | ]; |
839 | 845 | ||
840 | $crawler = $client->submit($form, $data); | 846 | $crawler = $client->submit($form, $data); |
841 | 847 | ||
842 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 848 | $this->assertCount(5, $crawler->filter('li.entry')); |
843 | 849 | ||
844 | $data = [ | 850 | $data = [ |
845 | 'entry_filter[createdAt][left_date]' => date('d/m/Y'), | 851 | 'entry_filter[createdAt][left_date]' => $today->format('Y-m-d'), |
846 | 'entry_filter[createdAt][right_date]' => date('d/m/Y'), | 852 | 'entry_filter[createdAt][right_date]' => $today->format('Y-m-d'), |
847 | ]; | 853 | ]; |
848 | 854 | ||
849 | $crawler = $client->submit($form, $data); | 855 | $crawler = $client->submit($form, $data); |
850 | 856 | ||
851 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 857 | $this->assertCount(5, $crawler->filter('li.entry')); |
852 | 858 | ||
853 | $data = [ | 859 | $data = [ |
854 | 'entry_filter[createdAt][left_date]' => '01/01/1970', | 860 | 'entry_filter[createdAt][left_date]' => '1970-01-01', |
855 | 'entry_filter[createdAt][right_date]' => '01/01/1970', | 861 | 'entry_filter[createdAt][right_date]' => '1970-01-01', |
856 | ]; | 862 | ]; |
857 | 863 | ||
858 | $crawler = $client->submit($form, $data); | 864 | $crawler = $client->submit($form, $data); |
859 | 865 | ||
860 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 866 | $this->assertCount(0, $crawler->filter('li.entry')); |
861 | } | 867 | } |
862 | 868 | ||
863 | public function testPaginationWithFilter() | 869 | public function testPaginationWithFilter() |
@@ -892,7 +898,6 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
892 | public function testFilterOnDomainName() | 898 | public function testFilterOnDomainName() |
893 | { | 899 | { |
894 | $this->logInAs('admin'); | 900 | $this->logInAs('admin'); |
895 | $this->useTheme('baggy'); | ||
896 | $client = $this->getClient(); | 901 | $client = $this->getClient(); |
897 | 902 | ||
898 | $crawler = $client->request('GET', '/unread/list'); | 903 | $crawler = $client->request('GET', '/unread/list'); |
@@ -902,7 +907,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
902 | ]; | 907 | ]; |
903 | 908 | ||
904 | $crawler = $client->submit($form, $data); | 909 | $crawler = $client->submit($form, $data); |
905 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 910 | $this->assertCount(5, $crawler->filter('li.entry')); |
906 | 911 | ||
907 | $crawler = $client->request('GET', '/unread/list'); | 912 | $crawler = $client->request('GET', '/unread/list'); |
908 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 913 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
@@ -911,7 +916,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
911 | ]; | 916 | ]; |
912 | 917 | ||
913 | $crawler = $client->submit($form, $data); | 918 | $crawler = $client->submit($form, $data); |
914 | $this->assertCount(5, $crawler->filter('div[class=entry]')); | 919 | $this->assertCount(5, $crawler->filter('li.entry')); |
915 | 920 | ||
916 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 921 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
917 | $data = [ | 922 | $data = [ |
@@ -919,13 +924,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
919 | ]; | 924 | ]; |
920 | 925 | ||
921 | $crawler = $client->submit($form, $data); | 926 | $crawler = $client->submit($form, $data); |
922 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 927 | $this->assertCount(0, $crawler->filter('li.entry')); |
923 | } | 928 | } |
924 | 929 | ||
925 | public function testFilterOnStatus() | 930 | public function testFilterOnStatus() |
926 | { | 931 | { |
927 | $this->logInAs('admin'); | 932 | $this->logInAs('admin'); |
928 | $this->useTheme('baggy'); | ||
929 | $client = $this->getClient(); | 933 | $client = $this->getClient(); |
930 | 934 | ||
931 | $crawler = $client->request('GET', '/unread/list'); | 935 | $crawler = $client->request('GET', '/unread/list'); |
@@ -934,20 +938,19 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
934 | $form['entry_filter[isStarred]']->untick(); | 938 | $form['entry_filter[isStarred]']->untick(); |
935 | 939 | ||
936 | $crawler = $client->submit($form); | 940 | $crawler = $client->submit($form); |
937 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 941 | $this->assertCount(1, $crawler->filter('li.entry')); |
938 | 942 | ||
939 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 943 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
940 | $form['entry_filter[isArchived]']->untick(); | 944 | $form['entry_filter[isArchived]']->untick(); |
941 | $form['entry_filter[isStarred]']->tick(); | 945 | $form['entry_filter[isStarred]']->tick(); |
942 | 946 | ||
943 | $crawler = $client->submit($form); | 947 | $crawler = $client->submit($form); |
944 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 948 | $this->assertCount(1, $crawler->filter('li.entry')); |
945 | } | 949 | } |
946 | 950 | ||
947 | public function testFilterOnIsPublic() | 951 | public function testFilterOnIsPublic() |
948 | { | 952 | { |
949 | $this->logInAs('admin'); | 953 | $this->logInAs('admin'); |
950 | $this->useTheme('baggy'); | ||
951 | $client = $this->getClient(); | 954 | $client = $this->getClient(); |
952 | 955 | ||
953 | $crawler = $client->request('GET', '/unread/list'); | 956 | $crawler = $client->request('GET', '/unread/list'); |
@@ -955,13 +958,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
955 | $form['entry_filter[isPublic]']->tick(); | 958 | $form['entry_filter[isPublic]']->tick(); |
956 | 959 | ||
957 | $crawler = $client->submit($form); | 960 | $crawler = $client->submit($form); |
958 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 961 | $this->assertCount(0, $crawler->filter('li.entry')); |
959 | } | 962 | } |
960 | 963 | ||
961 | public function testPreviewPictureFilter() | 964 | public function testPreviewPictureFilter() |
962 | { | 965 | { |
963 | $this->logInAs('admin'); | 966 | $this->logInAs('admin'); |
964 | $this->useTheme('baggy'); | ||
965 | $client = $this->getClient(); | 967 | $client = $this->getClient(); |
966 | 968 | ||
967 | $crawler = $client->request('GET', '/unread/list'); | 969 | $crawler = $client->request('GET', '/unread/list'); |
@@ -969,13 +971,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
969 | $form['entry_filter[previewPicture]']->tick(); | 971 | $form['entry_filter[previewPicture]']->tick(); |
970 | 972 | ||
971 | $crawler = $client->submit($form); | 973 | $crawler = $client->submit($form); |
972 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 974 | $this->assertCount(1, $crawler->filter('li.entry')); |
973 | } | 975 | } |
974 | 976 | ||
975 | public function testFilterOnLanguage() | 977 | public function testFilterOnLanguage() |
976 | { | 978 | { |
977 | $this->logInAs('admin'); | 979 | $this->logInAs('admin'); |
978 | $this->useTheme('baggy'); | ||
979 | $client = $this->getClient(); | 980 | $client = $this->getClient(); |
980 | 981 | ||
981 | $entry = new Entry($this->getLoggedInUser()); | 982 | $entry = new Entry($this->getLoggedInUser()); |
@@ -991,7 +992,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
991 | ]; | 992 | ]; |
992 | 993 | ||
993 | $crawler = $client->submit($form, $data); | 994 | $crawler = $client->submit($form, $data); |
994 | $this->assertCount(3, $crawler->filter('div[class=entry]')); | 995 | $this->assertCount(3, $crawler->filter('li.entry')); |
995 | 996 | ||
996 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 997 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
997 | $data = [ | 998 | $data = [ |
@@ -999,7 +1000,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
999 | ]; | 1000 | ]; |
1000 | 1001 | ||
1001 | $crawler = $client->submit($form, $data); | 1002 | $crawler = $client->submit($form, $data); |
1002 | $this->assertCount(2, $crawler->filter('div[class=entry]')); | 1003 | $this->assertCount(2, $crawler->filter('li.entry')); |
1003 | } | 1004 | } |
1004 | 1005 | ||
1005 | public function testShareEntryPublicly() | 1006 | public function testShareEntryPublicly() |
@@ -1181,7 +1182,6 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1181 | public function testFilterOnHttpStatus() | 1182 | public function testFilterOnHttpStatus() |
1182 | { | 1183 | { |
1183 | $this->logInAs('admin'); | 1184 | $this->logInAs('admin'); |
1184 | $this->useTheme('baggy'); | ||
1185 | $client = $this->getClient(); | 1185 | $client = $this->getClient(); |
1186 | 1186 | ||
1187 | $entry = new Entry($this->getLoggedInUser()); | 1187 | $entry = new Entry($this->getLoggedInUser()); |
@@ -1200,7 +1200,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1200 | 1200 | ||
1201 | $crawler = $client->submit($form, $data); | 1201 | $crawler = $client->submit($form, $data); |
1202 | 1202 | ||
1203 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 1203 | $this->assertCount(1, $crawler->filter('li.entry')); |
1204 | 1204 | ||
1205 | $entry = new Entry($this->getLoggedInUser()); | 1205 | $entry = new Entry($this->getLoggedInUser()); |
1206 | $entry->setUrl($this->url); | 1206 | $entry->setUrl($this->url); |
@@ -1223,7 +1223,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1223 | 1223 | ||
1224 | $crawler = $client->submit($form, $data); | 1224 | $crawler = $client->submit($form, $data); |
1225 | 1225 | ||
1226 | $this->assertCount(2, $crawler->filter('div[class=entry]')); | 1226 | $this->assertCount(2, $crawler->filter('li.entry')); |
1227 | 1227 | ||
1228 | $crawler = $client->request('GET', '/all/list'); | 1228 | $crawler = $client->request('GET', '/all/list'); |
1229 | $form = $crawler->filter('button[id=submit-filter]')->form(); | 1229 | $form = $crawler->filter('button[id=submit-filter]')->form(); |
@@ -1234,13 +1234,12 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1234 | 1234 | ||
1235 | $crawler = $client->submit($form, $data); | 1235 | $crawler = $client->submit($form, $data); |
1236 | 1236 | ||
1237 | $this->assertCount(8, $crawler->filter('div[class=entry]')); | 1237 | $this->assertCount(8, $crawler->filter('li.entry')); |
1238 | } | 1238 | } |
1239 | 1239 | ||
1240 | public function testSearch() | 1240 | public function testSearch() |
1241 | { | 1241 | { |
1242 | $this->logInAs('admin'); | 1242 | $this->logInAs('admin'); |
1243 | $this->useTheme('baggy'); | ||
1244 | $client = $this->getClient(); | 1243 | $client = $this->getClient(); |
1245 | 1244 | ||
1246 | $entry = new Entry($this->getLoggedInUser()); | 1245 | $entry = new Entry($this->getLoggedInUser()); |
@@ -1259,7 +1258,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1259 | 1258 | ||
1260 | $crawler = $client->submit($form, $data); | 1259 | $crawler = $client->submit($form, $data); |
1261 | 1260 | ||
1262 | $this->assertCount(4, $crawler->filter('div[class=entry]')); | 1261 | $this->assertCount(4, $crawler->filter('li.entry')); |
1263 | 1262 | ||
1264 | // Search on starred list | 1263 | // Search on starred list |
1265 | $crawler = $client->request('GET', '/starred/list'); | 1264 | $crawler = $client->request('GET', '/starred/list'); |
@@ -1278,7 +1277,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1278 | 1277 | ||
1279 | $crawler = $client->submit($form, $data); | 1278 | $crawler = $client->submit($form, $data); |
1280 | 1279 | ||
1281 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 1280 | $this->assertCount(1, $crawler->filter('li.entry')); |
1282 | 1281 | ||
1283 | $crawler = $client->request('GET', '/archive/list'); | 1282 | $crawler = $client->request('GET', '/archive/list'); |
1284 | 1283 | ||
@@ -1297,7 +1296,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1297 | 1296 | ||
1298 | $crawler = $client->submit($form, $data); | 1297 | $crawler = $client->submit($form, $data); |
1299 | 1298 | ||
1300 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 1299 | $this->assertCount(1, $crawler->filter('li.entry')); |
1301 | $client->request('GET', '/delete/' . $entry->getId()); | 1300 | $client->request('GET', '/delete/' . $entry->getId()); |
1302 | 1301 | ||
1303 | // test on list of all articles | 1302 | // test on list of all articles |
@@ -1310,7 +1309,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1310 | 1309 | ||
1311 | $crawler = $client->submit($form, $data); | 1310 | $crawler = $client->submit($form, $data); |
1312 | 1311 | ||
1313 | $this->assertCount(0, $crawler->filter('div[class=entry]')); | 1312 | $this->assertCount(0, $crawler->filter('li.entry')); |
1314 | 1313 | ||
1315 | // test url search on list of all articles | 1314 | // test url search on list of all articles |
1316 | $entry = new Entry($this->getLoggedInUser()); | 1315 | $entry = new Entry($this->getLoggedInUser()); |
@@ -1329,7 +1328,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1329 | 1328 | ||
1330 | $crawler = $client->submit($form, $data); | 1329 | $crawler = $client->submit($form, $data); |
1331 | 1330 | ||
1332 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 1331 | $this->assertCount(1, $crawler->filter('li.entry')); |
1333 | 1332 | ||
1334 | // same as previous test but for case-sensitivity | 1333 | // same as previous test but for case-sensitivity |
1335 | $crawler = $client->request('GET', '/all/list'); | 1334 | $crawler = $client->request('GET', '/all/list'); |
@@ -1341,7 +1340,7 @@ class EntryControllerTest extends WallabagCoreTestCase | |||
1341 | 1340 | ||
1342 | $crawler = $client->submit($form, $data); | 1341 | $crawler = $client->submit($form, $data); |
1343 | 1342 | ||
1344 | $this->assertCount(1, $crawler->filter('div[class=entry]')); | 1343 | $this->assertCount(1, $crawler->filter('li.entry')); |
1345 | } | 1344 | } |
1346 | 1345 | ||
1347 | public function dataForLanguage() | 1346 | public function dataForLanguage() |
diff --git a/tests/Wallabag/CoreBundle/Controller/ExportControllerTest.php b/tests/Wallabag/CoreBundle/Controller/ExportControllerTest.php index d7ce7c45..36822ab3 100644 --- a/tests/Wallabag/CoreBundle/Controller/ExportControllerTest.php +++ b/tests/Wallabag/CoreBundle/Controller/ExportControllerTest.php | |||
@@ -3,9 +3,13 @@ | |||
3 | namespace Tests\Wallabag\CoreBundle\Controller; | 3 | namespace Tests\Wallabag\CoreBundle\Controller; |
4 | 4 | ||
5 | use Tests\Wallabag\CoreBundle\WallabagCoreTestCase; | 5 | use Tests\Wallabag\CoreBundle\WallabagCoreTestCase; |
6 | use Wallabag\CoreBundle\Entity\Entry; | ||
6 | 7 | ||
7 | class ExportControllerTest extends WallabagCoreTestCase | 8 | class ExportControllerTest extends WallabagCoreTestCase |
8 | { | 9 | { |
10 | private $adminEntry; | ||
11 | private $bobEntry; | ||
12 | |||
9 | public function testLogin() | 13 | public function testLogin() |
10 | { | 14 | { |
11 | $client = $this->getClient(); | 15 | $client = $this->getClient(); |
@@ -243,6 +247,30 @@ class ExportControllerTest extends WallabagCoreTestCase | |||
243 | $this->assertContains('foo', $content[0]['tags']); | 247 | $this->assertContains('foo', $content[0]['tags']); |
244 | } | 248 | } |
245 | 249 | ||
250 | public function testJsonExportFromSearch() | ||
251 | { | ||
252 | $this->setUpForJsonExportFromSearch(); | ||
253 | |||
254 | $this->logInAs('admin'); | ||
255 | $client = $this->getClient(); | ||
256 | |||
257 | ob_start(); | ||
258 | $crawler = $client->request('GET', '/export/search.json?search_entry[term]=entry+search¤tRoute=homepage'); | ||
259 | ob_end_clean(); | ||
260 | |||
261 | $this->assertSame(200, $client->getResponse()->getStatusCode()); | ||
262 | |||
263 | $headers = $client->getResponse()->headers; | ||
264 | $this->assertSame('application/json', $headers->get('content-type')); | ||
265 | $this->assertSame('attachment; filename="Search entry search articles.json"', $headers->get('content-disposition')); | ||
266 | $this->assertSame('UTF-8', $headers->get('content-transfer-encoding')); | ||
267 | |||
268 | $content = json_decode($client->getResponse()->getContent(), true); | ||
269 | $this->assertCount(1, $content); | ||
270 | |||
271 | $this->tearDownForJsonExportFromSearch(); | ||
272 | } | ||
273 | |||
246 | public function testXmlExport() | 274 | public function testXmlExport() |
247 | { | 275 | { |
248 | $this->logInAs('admin'); | 276 | $this->logInAs('admin'); |
@@ -282,6 +310,41 @@ class ExportControllerTest extends WallabagCoreTestCase | |||
282 | $this->assertNotEmpty('updated_at', (string) $content->entry[0]->updated_at); | 310 | $this->assertNotEmpty('updated_at', (string) $content->entry[0]->updated_at); |
283 | } | 311 | } |
284 | 312 | ||
313 | private function setUpForJsonExportFromSearch() | ||
314 | { | ||
315 | $client = $this->getClient(); | ||
316 | $em = $this->getEntityManager(); | ||
317 | |||
318 | $userRepository = $client->getContainer() | ||
319 | ->get('wallabag_user.user_repository.test'); | ||
320 | |||
321 | $user = $userRepository->findOneByUserName('admin'); | ||
322 | $this->adminEntry = new Entry($user); | ||
323 | $this->adminEntry->setUrl('http://0.0.0.0/entry-search-admin'); | ||
324 | $this->adminEntry->setTitle('test title entry search admin'); | ||
325 | $this->adminEntry->setContent('this is my content /o/'); | ||
326 | $em->persist($this->adminEntry); | ||
327 | |||
328 | $user = $userRepository->findOneByUserName('bob'); | ||
329 | $this->bobEntry = new Entry($user); | ||
330 | $this->bobEntry->setUrl('http://0.0.0.0/entry-search-bob'); | ||
331 | $this->bobEntry->setTitle('test title entry search bob'); | ||
332 | $this->bobEntry->setContent('this is my content /o/'); | ||
333 | $em->persist($this->bobEntry); | ||
334 | |||
335 | $em->flush(); | ||
336 | } | ||
337 | |||
338 | private function tearDownForJsonExportFromSearch() | ||
339 | { | ||
340 | $em = $this->getEntityManager(); | ||
341 | |||
342 | $em->remove($this->adminEntry); | ||
343 | $em->remove($this->bobEntry); | ||
344 | |||
345 | $em->flush(); | ||
346 | } | ||
347 | |||
285 | private function getSanitizedFilename($title) | 348 | private function getSanitizedFilename($title) |
286 | { | 349 | { |
287 | return preg_replace('/[^A-Za-z0-9\- \']/', '', iconv('utf-8', 'us-ascii//TRANSLIT', $title)); | 350 | return preg_replace('/[^A-Za-z0-9\- \']/', '', iconv('utf-8', 'us-ascii//TRANSLIT', $title)); |