To reproduce the issue:
- Create a simple Django app.
- Install selenium and requests
- Add a testcase like so:
{{{#!python
import time
from django.contrib.staticfiles.testing import StaticLiveServerTestCase
from django.urls import reverse
from selenium import webdriver
class TestExample(StaticLiveServerTestCase):
def test_example(self):
driver = webdriver.Chrome()
driver.get(self.live_server_url + reverse('admin:index'))
# wait "forever"
time.sleep(60 * 60 * 24)
}}}
I.e it just opens the admin page, then waits for 24 hours. In a Python
console, type the following:
{{{#!python
import requests
requests.get('http://localhost:47256/admin')
}}}
and you will see that the request hangs indefinitely. Interestingly, it
sometimes helps to press refresh in the Chrome window spawned by Selenium.
--
Ticket URL: <https://code.djangoproject.com/ticket/29305>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
Old description:
New description:
We have an integration test where we start two separate Django processes
and the second process makes a POST request to the first process with the
requests library. This testcase broke once we upgraded to Django 1.11,
while it still worked in Django 1.10.
To reproduce the issue:
- Create a simple Django app.
- Install selenium and requests
- Add a testcase like so:
{{{#!python
import time
from django.contrib.staticfiles.testing import StaticLiveServerTestCase
from django.urls import reverse
from selenium import webdriver
class TestExample(StaticLiveServerTestCase):
def test_example(self):
driver = webdriver.Chrome()
driver.get(self.live_server_url + reverse('admin:index'))
# wait "forever"
time.sleep(60 * 60 * 24)
}}}
I.e it just opens the admin page, then waits for 24 hours. In a Python
console, type the following:
{{{#!python
import requests
requests.get('http://localhost:47256/admin') # replace 47256 with whatever
port number the LiveServerTestCase picked
}}}
and you will see that the request hangs indefinitely. Interestingly, it
sometimes helps to press refresh in the Chrome window spawned by Selenium.
--
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:1>
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:2>
Old description:
> We have an integration test where we start two separate Django processes
> and the second process makes a POST request to the first process with the
> requests library. This testcase broke once we upgraded to Django 1.11,
> while it still worked in Django 1.10.
>
> To reproduce the issue:
>
> - Create a simple Django app.
> - Install selenium and requests
> - Add a testcase like so:
>
> {{{#!python
> import time
>
> from django.contrib.staticfiles.testing import StaticLiveServerTestCase
> from django.urls import reverse
> from selenium import webdriver
>
> class TestExample(StaticLiveServerTestCase):
> def test_example(self):
> driver = webdriver.Chrome()
> driver.get(self.live_server_url + reverse('admin:index'))
> # wait "forever"
> time.sleep(60 * 60 * 24)
> }}}
>
> I.e it just opens the admin page, then waits for 24 hours. In a Python
> console, type the following:
>
> {{{#!python
> import requests
> requests.get('http://localhost:47256/admin') # replace 47256 with
> whatever port number the LiveServerTestCase picked
> }}}
>
> and you will see that the request hangs indefinitely. Interestingly, it
> sometimes helps to press refresh in the Chrome window spawned by
> Selenium.
New description:
We have an integration test where we start two separate Django processes
and the second process makes a POST request to the first process with the
requests library. This testcase broke once we upgraded to Django 1.11,
while it still worked in Django 1.10.
To reproduce the issue:
- Create a simple Django app.
- Install selenium and requests
- Add a testcase like so:
{{{#!python
import time
from django.contrib.staticfiles.testing import StaticLiveServerTestCase
from django.urls import reverse
from selenium import webdriver
class TestExample(StaticLiveServerTestCase):
def test_example(self):
driver = webdriver.Chrome()
driver.get(self.live_server_url + reverse('admin:index'))
# wait "forever"
time.sleep(60 * 60 * 24)
}}}
I.e it just opens the admin page in Chrome, then waits for 24 hours. In a
Python console, type the following:
{{{#!python
import requests
requests.get('http://localhost:47256/admin') # replace 47256 with whatever
port number the LiveServerTestCase picked
}}}
and you will see that the request hangs indefinitely. Interestingly, it
sometimes helps to press refresh in the Chrome window spawned by Selenium.
--
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:3>
Old description:
> We have an integration test where we start two separate Django processes
> and the second process makes a POST request to the first process with the
> requests library. This testcase broke once we upgraded to Django 1.11,
> while it still worked in Django 1.10.
>
> To reproduce the issue:
>
> - Create a simple Django app.
> - Install selenium and requests
> - Add a testcase like so:
>
> {{{#!python
> import time
>
> from django.contrib.staticfiles.testing import StaticLiveServerTestCase
> from django.urls import reverse
> from selenium import webdriver
>
> class TestExample(StaticLiveServerTestCase):
> def test_example(self):
> driver = webdriver.Chrome()
> driver.get(self.live_server_url + reverse('admin:index'))
> # wait "forever"
> time.sleep(60 * 60 * 24)
> }}}
>
> I.e it just opens the admin page in Chrome, then waits for 24 hours. In a
> Python console, type the following:
>
> {{{#!python
> import requests
> requests.get('http://localhost:47256/admin') # replace 47256 with
> whatever port number the LiveServerTestCase picked
> }}}
>
> and you will see that the request hangs indefinitely. Interestingly, it
> sometimes helps to press refresh in the Chrome window spawned by
> Selenium.
New description:
We have an integration test where we start two separate Django processes
and the second process makes a POST request to the first process with the
requests library. This testcase broke once we upgraded to Django 1.11,
while it still worked in Django 1.10.
To reproduce the issue:
- Create a simple Django app.
- Install selenium and requests
- Add a testcase like so:
{{{#!python
import time
from django.contrib.staticfiles.testing import StaticLiveServerTestCase
from django.urls import reverse
from selenium import webdriver
class TestExample(StaticLiveServerTestCase):
def test_example(self):
driver = webdriver.Chrome()
driver.get(self.live_server_url + reverse('admin:index'))
# wait "forever"
time.sleep(60 * 60 * 24)
}}}
I.e it just opens the admin page in Chrome, then waits for 24 hours. In a
Python console, type the following:
{{{#!python
import requests
requests.get('http://localhost:47256/admin') # replace 47256 with whatever
port number the LiveServerTestCase picked
}}}
and you will see that the request hangs indefinitely. Interestingly, it
sometimes helps to press refresh in the Chrome window spawned by Selenium.
I am seeing this issue on Windows 7 and Windows 10 machines
--
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:4>
Comment (by Tim Graham):
I can reproduce with Django 1.11.x but not with Django 2.0.x. Do you get
the same result? If so, it might be a bit late to fix the issue for Django
1.11.x unless the fix is trivial.
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:5>
Comment (by Santiago García):
Yes, it does work for me on Django 2.0
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:6>
* status: new => closed
* resolution: => wontfix
--
Ticket URL: <https://code.djangoproject.com/ticket/29305#comment:7>