test_download.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. # Copyright 2021-2024 Avaiga Private Limited
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  4. # the License. You may obtain a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  9. # an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
  10. # specific language governing permissions and limitations under the License.
  11. import inspect
  12. import typing as t
  13. import warnings
  14. from flask import Flask, g
  15. from taipy.gui import Gui, Markdown, State, download
  16. def test_download(gui: Gui, helpers):
  17. name = "World!" # noqa: F841
  18. btn_id = "button1" # noqa: F841
  19. def on_download_action(state: State):
  20. pass
  21. # set gui frame
  22. gui._set_frame(inspect.currentframe())
  23. gui.add_page("test", Markdown("<|Hello {name}|button|id={btn_id}|>"))
  24. gui.run(run_server=False)
  25. flask_client = gui._server.test_client()
  26. # WS client and emit
  27. ws_client = gui._server._ws.test_client(gui._server.get_flask())
  28. cid = helpers.create_scope_and_get_sid(gui)
  29. # Get the jsx once so that the page will be evaluated -> variable will be registered
  30. flask_client.get(f"/taipy-jsx/test?client_id={cid}")
  31. with gui.get_flask_app().test_request_context(f"/taipy-jsx/test/?client_id={cid}", data={"client_id": cid}):
  32. g.client_id = cid
  33. download(gui._Gui__state, "some text", "filename.txt", "on_download_action") # type: ignore[attr-defined]
  34. received_messages = ws_client.get_received()
  35. helpers.assert_outward_ws_simple_message(
  36. received_messages[0], "DF", {"name": "filename.txt", "onAction": "on_download_action"}
  37. )
  38. def test_download_fn(gui: Gui, helpers):
  39. def on_download_action(state: State):
  40. pass
  41. # set gui frame
  42. gui._set_frame(inspect.currentframe())
  43. gui.add_page("test", Markdown("<|Hello|button|>"))
  44. gui.run(run_server=False)
  45. flask_client = gui._server.test_client()
  46. # WS client and emit
  47. ws_client = gui._server._ws.test_client(t.cast(Flask, gui._server.get_flask()))
  48. cid = helpers.create_scope_and_get_sid(gui)
  49. flask_client.get(f"/taipy-jsx/test?client_id={cid}")
  50. with gui.get_flask_app().test_request_context(f"/taipy-jsx/test/?client_id={cid}", data={"client_id": cid}):
  51. g.client_id = cid
  52. download(gui._Gui__state, "some text", "filename.txt", on_download_action) # type: ignore[attr-defined]
  53. received_messages = ws_client.get_received()
  54. helpers.assert_outward_ws_simple_message(
  55. received_messages[0],
  56. "DF",
  57. {"name": "filename.txt", "context": "test_download", "onAction": "tp_on_download_action_0"},
  58. )
  59. def test_bad_download(gui: Gui, helpers):
  60. with warnings.catch_warnings(record=True) as records:
  61. download(None, "some text", "filename.txt", "on_download_action") # type: ignore[arg-type]
  62. assert len(records) == 1