2025-08-19T17:49:16.354067049Z [migrations] started 2025-08-19T17:49:16.358038116Z [migrations] no migrations found 2025-08-19T17:49:16.821683380Z usermod: no changes 2025-08-19T17:49:16.901729561Z ─────────────────────────────────────── 2025-08-19T17:49:16.901774402Z 2025-08-19T17:49:16.901786586Z ██╗ ███████╗██╗ ██████╗ 2025-08-19T17:49:16.901797719Z ██║ ██╔════╝██║██╔═══██╗ 2025-08-19T17:49:16.901809071Z ██║ ███████╗██║██║ ██║ 2025-08-19T17:49:16.901819783Z ██║ ╚════██║██║██║ ██║ 2025-08-19T17:49:16.901830284Z ███████╗███████║██║╚██████╔╝ 2025-08-19T17:49:16.901840605Z ╚══════╝╚══════╝╚═╝ ╚═════╝ 2025-08-19T17:49:16.901851206Z 2025-08-19T17:49:16.901861216Z Brought to you by linuxserver.io 2025-08-19T17:49:16.901871377Z ─────────────────────────────────────── 2025-08-19T17:49:16.906684620Z 2025-08-19T17:49:16.906711113Z To support LSIO projects visit: 2025-08-19T17:49:16.906721705Z https://www.linuxserver.io/donate/ 2025-08-19T17:49:16.906731685Z 2025-08-19T17:49:16.906741705Z ─────────────────────────────────────── 2025-08-19T17:49:16.906752938Z GID/UID 2025-08-19T17:49:16.906959684Z ─────────────────────────────────────── 2025-08-19T17:49:16.979005874Z 2025-08-19T17:49:16.979040604Z User UID: 911 2025-08-19T17:49:16.979049252Z User GID: 911 2025-08-19T17:49:16.979057408Z ─────────────────────────────────────── 2025-08-19T17:49:17.015802237Z Linuxserver.io version: 0.50.10-ls211 2025-08-19T17:49:17.019819738Z Build-date: 2025-08-19T17:43:39+00:00 2025-08-19T17:49:17.019870009Z ─────────────────────────────────────── 2025-08-19T17:49:17.019883687Z 2025-08-19T17:49:19.174916076Z [custom-init] No custom files found, skipping... 2025-08-19T17:49:22.069952656Z /app/changedetection/changedetectionio/html_tools.py:431: SyntaxWarning: invalid escape sequence '\[' 2025-08-19T17:49:22.069985502Z pattern = '<!\[CDATA\[(\s*(?:.(?<!\]\]>)\s*)*)\]\]>' 2025-08-19T17:49:22.073946679Z /app/changedetection/changedetectionio/html_tools.py:495: SyntaxWarning: invalid escape sequence '\s' 2025-08-19T17:49:22.073998964Z content = re.sub('<!--\s+-->', '', content) 2025-08-19T17:49:22.879765771Z 2025-08-19 17:49:22.876 | DEBUG | changedetectionio.content_fetchers:<module>:62 - Falling back to selenium as fetcher 2025-08-19T17:49:24.328315016Z 2025-08-19 17:49:24.327 | DEBUG | changedetectionio.queue_handlers:__init__:53 - RecheckPriorityQueue initialized successfully 2025-08-19T17:49:24.328858731Z 2025-08-19 17:49:24.328 | DEBUG | changedetectionio.queue_handlers:__init__:358 - NotificationQueue initialized successfully 2025-08-19T17:49:24.371731610Z 2025-08-19 17:49:24.371 | INFO | changedetectionio.flask_app:<module>:90 - System locale default is (None, None) 2025-08-19T17:49:24.380872198Z 2025-08-19 17:49:24.380 | SUCCESS | changedetectionio:main:131 - changedetection.io version 0.50.10 starting. 2025-08-19T17:49:24.550321955Z 2025-08-19 17:49:24.549 | INFO | changedetectionio.store:__init__:50 - Datastore path is '/config/url-watches.json' 2025-08-19T17:49:24.554412473Z 2025-08-19 17:49:24.553 | CRITICAL | changedetectionio.store:__init__:100 - No JSON DB found at /config/url-watches.json, creating JSON store at /config 2025-08-19T17:49:25.221084032Z 2025-08-19 17:49:25.220 | DEBUG | changedetectionio.store:add_tag:591 - >>> Adding new tag - 'tech news' 2025-08-19T17:49:25.781359725Z 2025-08-19 17:49:25.780 | DEBUG | changedetectionio.store:add_watch:367 - Adding URL 'https://news.ycombinator.com/' - be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:25.782060466Z 2025-08-19 17:49:25.781 | DEBUG | changedetectionio.model.Watch:ensure_data_dir_exists:73 - > Creating data dir /config/be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:25.782743982Z 2025-08-19 17:49:25.782 | INFO | changedetectionio.store:sync_to_json:397 - Saving JSON.. 2025-08-19T17:49:25.803681557Z 2025-08-19 17:49:25.803 | DEBUG | changedetectionio.store:add_watch:383 - Added 'https://news.ycombinator.com/' 2025-08-19T17:49:25.804620358Z 2025-08-19 17:49:25.804 | DEBUG | changedetectionio.store:add_tag:591 - >>> Adding new tag - 'changedetection.io' 2025-08-19T17:49:25.808108663Z 2025-08-19 17:49:25.807 | DEBUG | changedetectionio.store:add_watch:367 - Adding URL 'https://changedetection.io/CHANGELOG.txt' - 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:25.808837842Z 2025-08-19 17:49:25.808 | DEBUG | changedetectionio.model.Watch:ensure_data_dir_exists:73 - > Creating data dir /config/3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:25.809470345Z 2025-08-19 17:49:25.809 | INFO | changedetectionio.store:sync_to_json:397 - Saving JSON.. 2025-08-19T17:49:25.851357800Z 2025-08-19 17:49:25.850 | DEBUG | changedetectionio.store:add_watch:383 - Added 'https://changedetection.io/CHANGELOG.txt' 2025-08-19T17:49:26.031373886Z 2025-08-19 17:49:25.959 | INFO | changedetectionio.store:sync_to_json:397 - Saving JSON.. 2025-08-19T17:49:27.022912439Z /app/changedetection/changedetectionio/blueprint/backups/__init__.py:124: SyntaxWarning: invalid escape sequence '\d' 2025-08-19T17:49:27.022943231Z backup_filename_regex = BACKUP_FILENAME_FORMAT.format("\d+") 2025-08-19T17:49:28.059011580Z 2025-08-19 17:49:28.058 | INFO | changedetectionio.realtime.socket_server:init_socketio:287 - SOCKETIO_MODE=threading: Using threading mode for Socket.IO 2025-08-19T17:49:28.059518030Z 2025-08-19 17:49:28.059 | INFO | changedetectionio.realtime.socket_server:init_socketio:294 - Platform: linux, Python: 3.12, Socket.IO mode: threading 2025-08-19T17:49:28.530836937Z 2025-08-19 17:49:28.529 | INFO | changedetectionio.realtime.socket_server:init_socketio:306 - Socket.IO: Registering connect event handler 2025-08-19T17:49:28.532422510Z 2025-08-19 17:49:28.531 | INFO | changedetectionio.realtime.socket_server:__init__:38 - SignalHandler: Connected to notification_event signal 2025-08-19T17:49:28.539069817Z 2025-08-19 17:49:28.537 | INFO | changedetectionio.realtime.socket_server:polling_emit_running_or_queued_watches_threaded:131 - Queue update thread started (threading mode) 2025-08-19T17:49:28.541422775Z 2025-08-19 17:49:28.539 | INFO | changedetectionio.realtime.socket_server:__init__:47 - Started polling thread using threading (eventlet-free) 2025-08-19T17:49:28.556495470Z 2025-08-19 17:49:28.555 | INFO | changedetectionio.realtime.socket_server:init_socketio:405 - Socket.IO initialized and attached to main Flask app 2025-08-19T17:49:28.557129827Z 2025-08-19 17:49:28.556 | INFO | changedetectionio.realtime.socket_server:init_socketio:406 - Socket.IO: Registered event handlers: [] 2025-08-19T17:49:28.557727711Z 2025-08-19 17:49:28.557 | INFO | changedetectionio.flask_app:changedetection_app:533 - Socket.IO server initialized 2025-08-19T17:49:28.581423120Z 2025-08-19 17:49:28.580 | INFO | changedetectionio.flask_app:changedetection_app:623 - Starting 10 workers during app initialization 2025-08-19T17:49:28.585540813Z 2025-08-19 17:49:28.584 | INFO | changedetectionio.worker_handler:start_async_event_loop:29 - Starting async event loop for workers 2025-08-19T17:49:28.591338949Z 2025-08-19 17:49:28.590 | DEBUG | changedetectionio.worker_handler:start_async_event_loop:37 - Event loop created and set: <_UnixSelectorEventLoop running=False closed=False debug=False> 2025-08-19T17:49:28.887275732Z 2025-08-19 17:49:28.886 | INFO | changedetectionio.worker_handler:start_async_workers:76 - Starting 10 async workers 2025-08-19T17:49:28.898094339Z 2025-08-19 17:49:28.896 | DEBUG | changedetectionio.flask_app:ticker_thread_check_time_launch_checks:728 - System env MINIMUM_SECONDS_RECHECK_TIME 3 2025-08-19T17:49:28.938122991Z 2025-08-19 17:49:28.937 | DEBUG | changedetectionio.realtime.socket_server:handle_queue_length:99 - SignalHandler: Queue length update received: 1 2025-08-19T17:49:28.938744393Z 2025-08-19 17:49:28.938 | DEBUG | changedetectionio.queue_handlers:put:72 - Successfully queued item: be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:28.939287767Z 2025-08-19 17:49:28.938 | DEBUG | changedetectionio.worker_handler:queue_item_async_safe:218 - Successfully queued item: be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:28.941550303Z 2025-08-19 17:49:28.941 | DEBUG | changedetectionio.flask_app:ticker_thread_check_time_launch_checks:854 - > Queued watch UUID be7e892e-5238-43d1-9e77-ebaeba99e051 last checked at 0 queued at 1755625768.90 priority 1755625768 jitter 0.00s, 1755625768.90s since last checked 2025-08-19T17:49:28.947839308Z 2025-08-19 17:49:28.947 | DEBUG | changedetectionio.realtime.socket_server:handle_queue_length:99 - SignalHandler: Queue length update received: 2 2025-08-19T17:49:28.948506041Z 2025-08-19 17:49:28.948 | DEBUG | changedetectionio.queue_handlers:put:72 - Successfully queued item: 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:28.949040377Z 2025-08-19 17:49:28.948 | DEBUG | changedetectionio.worker_handler:queue_item_async_safe:218 - Successfully queued item: 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:28.949731158Z 2025-08-19 17:49:28.949 | DEBUG | changedetectionio.flask_app:ticker_thread_check_time_launch_checks:854 - > Queued watch UUID 3e9e0f33-496f-4c79-aafd-25c1f9719b4f last checked at 0 queued at 1755625768.94 priority 1755625768 jitter 0.00s, 1755625768.94s since last checked 2025-08-19T17:49:28.957784166Z Werkzeug appears to be used in a production deployment. Consider switching to a production web server instead. 2025-08-19T17:49:29.064077455Z 2025-08-19 17:49:29.062 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 0 2025-08-19T17:49:29.065630633Z 2025-08-19 17:49:29.064 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 0 2025-08-19T17:49:29.068190849Z * Serving Flask app 'changedetectionio.flask_app' 2025-08-19T17:49:29.068464179Z * Debug mode: off 2025-08-19T17:49:29.071798955Z 2025-08-19 17:49:29.070 | DEBUG | changedetectionio.realtime.socket_server:handle_queue_length:99 - SignalHandler: Queue length update received: 1 2025-08-19T17:49:29.073801618Z 2025-08-19 17:49:29.073 | DEBUG | changedetectionio.queue_handlers:async_get:155 - Successfully async retrieved item: be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:29.077058336Z 2025-08-19 17:49:29.076 | DEBUG | changedetectionio.worker_handler:set_uuid_processing:179 - Started processing UUID: be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:29.078706015Z 2025-08-19 17:49:29.077 | INFO | changedetectionio.async_update_worker:async_update_worker:81 - Worker 0 processing watch UUID be7e892e-5238-43d1-9e77-ebaeba99e051 Priority 1755625768 URL https://news.ycombinator.com/ 2025-08-19T17:49:29.100830510Z WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead. 2025-08-19T17:49:29.100840861Z * Running on all addresses (0.0.0.0) 2025-08-19T17:49:29.100847284Z * Running on http://127.0.0.1:5000 2025-08-19T17:49:29.100854037Z * Running on http://172.17.0.4:5000 2025-08-19T17:49:29.101233892Z Press CTRL+C to quit 2025-08-19T17:49:29.358735623Z 2025-08-19 17:49:29.357 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 1 2025-08-19T17:49:29.359251672Z 2025-08-19 17:49:29.358 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 1 2025-08-19T17:49:29.360370816Z 2025-08-19 17:49:29.359 | DEBUG | changedetectionio.realtime.socket_server:handle_queue_length:99 - SignalHandler: Queue length update received: 0 2025-08-19T17:49:29.361015755Z 2025-08-19 17:49:29.360 | DEBUG | changedetectionio.queue_handlers:async_get:155 - Successfully async retrieved item: 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:29.361849023Z 2025-08-19 17:49:29.361 | DEBUG | changedetectionio.worker_handler:set_uuid_processing:179 - Started processing UUID: 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:29.362725298Z 2025-08-19 17:49:29.362 | INFO | changedetectionio.async_update_worker:async_update_worker:81 - Worker 1 processing watch UUID 3e9e0f33-496f-4c79-aafd-25c1f9719b4f Priority 1755625768 URL https://changedetection.io/CHANGELOG.txt 2025-08-19T17:49:29.396280062Z 2025-08-19 17:49:29.395 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 2 2025-08-19T17:49:29.396836132Z 2025-08-19 17:49:29.396 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 2 2025-08-19T17:49:29.397731325Z 2025-08-19 17:49:29.397 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 3 2025-08-19T17:49:29.398278958Z 2025-08-19 17:49:29.397 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 3 2025-08-19T17:49:29.399115953Z 2025-08-19 17:49:29.398 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 4 2025-08-19T17:49:29.399701051Z 2025-08-19 17:49:29.399 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 4 2025-08-19T17:49:29.400549530Z 2025-08-19 17:49:29.400 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 5 2025-08-19T17:49:29.401092493Z 2025-08-19 17:49:29.400 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 5 2025-08-19T17:49:29.401894368Z 2025-08-19 17:49:29.401 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 6 2025-08-19T17:49:29.402436049Z 2025-08-19 17:49:29.401 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 6 2025-08-19T17:49:29.403248004Z 2025-08-19 17:49:29.402 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 7 2025-08-19T17:49:29.403749183Z 2025-08-19 17:49:29.403 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 7 2025-08-19T17:49:29.404596851Z 2025-08-19 17:49:29.404 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 8 2025-08-19T17:49:29.405139393Z 2025-08-19 17:49:29.404 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 8 2025-08-19T17:49:29.407336408Z 2025-08-19 17:49:29.405 | INFO | changedetectionio.worker_handler:start_single_async_worker:106 - Starting async worker 9 2025-08-19T17:49:29.407910103Z 2025-08-19 17:49:29.407 | INFO | changedetectionio.async_update_worker:async_update_worker:34 - Starting async worker 9 2025-08-19T17:49:30.036688690Z Connection to localhost (127.0.0.1) 5000 port [tcp/*] succeeded! 2025-08-19T17:49:30.407139183Z [ls.io-init] done. 2025-08-19T17:49:32.829610874Z 2025-08-19 17:49:32.828 | DEBUG | changedetectionio.processors.text_json_diff.processor:run_changedetection:367 - Watch UUID be7e892e-5238-43d1-9e77-ebaeba99e051 content check - Previous MD5: ef2a588594148762d2697bce68a284c5, Fetched MD5 ef2a588594148762d2697bce68a284c5 2025-08-19T17:49:33.787659101Z 2025-08-19 17:49:33.786 | DEBUG | changedetectionio.model.Watch:history:207 - Reading watch history index for be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:33.790174287Z 2025-08-19 17:49:33.789 | DEBUG | changedetectionio.worker_handler:set_uuid_processing:182 - Finished processing UUID: be7e892e-5238-43d1-9e77-ebaeba99e051 2025-08-19T17:49:33.792744302Z 2025-08-19 17:49:33.792 | DEBUG | changedetectionio.async_update_worker:async_update_worker:397 - Worker 0 completed watch be7e892e-5238-43d1-9e77-ebaeba99e051 in 4.79s 2025-08-19T17:49:34.433129864Z 2025-08-19 17:49:34.432 | DEBUG | changedetectionio.processors.text_json_diff.processor:run_changedetection:367 - Watch UUID 3e9e0f33-496f-4c79-aafd-25c1f9719b4f content check - Previous MD5: 47d714b625763699d036d1e4e1cacc86, Fetched MD5 47d714b625763699d036d1e4e1cacc86 2025-08-19T17:49:37.130457413Z 2025-08-19 17:49:37.129 | DEBUG | changedetectionio.model.Watch:history:207 - Reading watch history index for 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:37.158003798Z 2025-08-19 17:49:37.157 | DEBUG | changedetectionio.worker_handler:set_uuid_processing:182 - Finished processing UUID: 3e9e0f33-496f-4c79-aafd-25c1f9719b4f 2025-08-19T17:49:37.175483940Z 2025-08-19 17:49:37.174 | DEBUG | changedetectionio.async_update_worker:async_update_worker:397 - Worker 1 completed watch 3e9e0f33-496f-4c79-aafd-25c1f9719b4f in 8.17s 2025-08-19T17:49:37.987489499Z 172.17.0.3 - - [19/Aug/2025 17:49:37] "GET / HTTP/1.1" 200 - 2025-08-19T17:49:38.082744879Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET / HTTP/1.1" 200 - 2025-08-19T17:49:38.156305519Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/styles/pure-min.css HTTP/1.1" 200 - 2025-08-19T17:49:38.198271092Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/jquery-3.6.0.min.js HTTP/1.1" 200 - 2025-08-19T17:49:38.205428957Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/styles/styles.css?v=0.50.10 HTTP/1.1" 200 - 2025-08-19T17:49:38.228822247Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/google-chrome-icon.png HTTP/1.1" 200 - 2025-08-19T17:49:38.234549591Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/socket.io.min.js HTTP/1.1" 200 - 2025-08-19T17:49:38.248179991Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/spread-white.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.293884874Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/pause.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.328671519Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/bell-off.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.337219323Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/play.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.362587160Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/csrf.js HTTP/1.1" 200 - 2025-08-19T17:49:38.420484898Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/watch-overview.js HTTP/1.1" 200 - 2025-08-19T17:49:38.429349870Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/feather-icons.min.js HTTP/1.1" 200 - 2025-08-19T17:49:38.461080421Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/generic_feed-icon.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.472242690Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/realtime.js HTTP/1.1" 200 - 2025-08-19T17:49:38.484603643Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/images/spread.svg HTTP/1.1" 200 - 2025-08-19T17:49:38.501014402Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/js/toggle-theme.js HTTP/1.1" 200 - 2025-08-19T17:49:38.600265740Z 2025-08-19 17:49:38.598 | DEBUG | changedetectionio.realtime.socket_server:handle_connect:356 - Socket.IO: Sent initial queue size 0 to new client 2025-08-19T17:49:38.601536950Z 2025-08-19 17:49:38.600 | INFO | changedetectionio.realtime.socket_server:handle_connect:360 - Socket.IO: Client connected 2025-08-19T17:49:38.609400545Z 172.17.0.3 - - [19/Aug/2025 17:49:38] "GET /static/favicons/favicon.ico HTTP/1.1" 200 - 2025-08-19T17:49:48.892474746Z 2025-08-19 17:49:48.891 | INFO | changedetectionio.realtime.socket_server:handle_disconnect:366 - Socket.IO: Client disconnected 2025-08-19T17:49:48.896717771Z 172.17.0.3 - - [19/Aug/2025 17:49:48] "GET /socket.io/?EIO=4&transport=websocket HTTP/1.1" 500 - 2025-08-19T17:49:48.908720522Z Error on request: 2025-08-19T17:49:48.908730773Z Traceback (most recent call last): 2025-08-19T17:49:48.908737547Z File "/lsiopy/lib/python3.12/site-packages/werkzeug/serving.py", line 370, in run_wsgi 2025-08-19T17:49:48.908742336Z execute(self.server.app) 2025-08-19T17:49:48.908746084Z File "/lsiopy/lib/python3.12/site-packages/werkzeug/serving.py", line 336, in execute 2025-08-19T17:49:48.908749831Z write(b"") 2025-08-19T17:49:48.908753849Z File "/lsiopy/lib/python3.12/site-packages/werkzeug/serving.py", line 261, in write 2025-08-19T17:49:48.908757878Z assert status_set is not None, "write() before start_response" 2025-08-19T17:49:48.908761675Z ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-08-19T17:49:48.908765483Z AssertionError: write() before start_response