test_ru.py 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  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. from taipy.gui import Gui, Markdown
  13. def test_ru_selector(gui: Gui, helpers, csvdata):
  14. # Bind test variables
  15. selected_val = ["value1", "value2"] # noqa: F841
  16. # set gui frame
  17. gui._set_frame(inspect.currentframe())
  18. # Bind a page so that the variable will be evaluated as expression
  19. gui.add_page(
  20. "test",
  21. Markdown("<|{selected_val}|selector|multiple|>"),
  22. )
  23. gui.run(run_server=False)
  24. flask_client = gui._server.test_client()
  25. # WS client and emit
  26. ws_client = gui._server._ws.test_client(gui._server.get_flask())
  27. sid = helpers.create_scope_and_get_sid(gui)
  28. # Get the jsx once so that the page will be evaluated -> variable will be registered
  29. flask_client.get(f"/taipy-jsx/test?client_id={sid}")
  30. ws_client.emit("message", {"client_id": sid, "type": "RU", "name": "", "payload": {"names": ["selected_val"]}})
  31. # assert for received message (message that would be sent to the front-end client)
  32. received_messages = ws_client.get_received()
  33. assert len(received_messages)
  34. helpers.assert_outward_ws_message(received_messages[0], "MU", "selected_val", ["value1", "value2"])