Browse Source

add test for _photo_command handling telegram.error.BadRequest when photo exceeds file size limit

Fabian Peter Hammerle 6 months ago
parent
commit
d554717b82
1 changed files with 44 additions and 0 deletions
  1. 44 0
      tests/test_photo_command.py

+ 44 - 0
tests/test_photo_command.py

@@ -15,9 +15,12 @@
 # You should have received a copy of the GNU General Public License
 # You should have received a copy of the GNU General Public License
 # along with this program.  If not, see <https://www.gnu.org/licenses/>.
 # along with this program.  If not, see <https://www.gnu.org/licenses/>.
 
 
+import collections
 import logging
 import logging
 import unittest.mock
 import unittest.mock
 
 
+import telegram.error
+
 # pylint: disable=import-private-name; tests
 # pylint: disable=import-private-name; tests
 from location_guessing_game_telegram_bot import _photo_command
 from location_guessing_game_telegram_bot import _photo_command
 
 
@@ -104,3 +107,44 @@ def test_send_solution_and_next_photo(caplog, wikimap_photos):
         "last_photo": wikimap_photos[1],
         "last_photo": wikimap_photos[1],
         "last_photo_message_id": "second photo message id",
         "last_photo_message_id": "second photo message id",
     }
     }
+
+
+def test__photo_command_file_size_exceeded(caplog, wikimap_photos):
+    update_mock = unittest.mock.MagicMock()
+    update_mock.effective_chat.send_photo.side_effect = [
+        telegram.error.BadRequest(
+            'File "/var/lib/engine/tmpfs_numa0/image.jpeg" of size 42 bytes is too big for a photo'
+        )
+    ] * 4 + [
+        collections.namedtuple("Photo", ["message_id"])(message_id="photo message id"),
+    ]
+    context_mock = unittest.mock.MagicMock()
+    context_mock.bot_data = {"photos": wikimap_photos[:1]}
+    context_mock.chat_data = {}
+    http_response_mock = unittest.mock.MagicMock()
+    with unittest.mock.patch(
+        "urllib.request.urlopen", return_value=http_response_mock
+    ) as urlopen_mock, caplog.at_level(logging.INFO):
+        _photo_command(update=update_mock, context=context_mock)
+    assert urlopen_mock.call_count == 4 + 1
+    assert update_mock.effective_chat.send_photo.call_count == 4 + 1
+    assert len(caplog.records) == 4 * 2 + 1
+    assert caplog.record_tuples[0::2] == [
+        (
+            "location_guessing_game_telegram_bot",
+            logging.INFO,
+            "sending photo https://commons.wikimedia.org/wiki"
+            "/File:H%C3%BCtteltalkopf_(Venedigergruppe)_from_Tristkopf.jpg",
+        )
+    ] * (4 + 1)
+    assert caplog.record_tuples[1::2] == [
+        (
+            "location_guessing_game_telegram_bot",
+            logging.WARNING,
+            "file size limit exceeded?",
+        )
+    ] * (4)
+    assert context_mock.chat_data == {
+        "last_photo": wikimap_photos[0],
+        "last_photo_message_id": "photo message id",
+    }