This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author Bogdan Popa
Recipients Bogdan Popa
Date 2017-11-17.10:17:39
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1510913860.03.0.213398074469.issue32057@psf.upfronthosting.co.za>
In-reply-to
Content
I ran into this while backporting some code from 3.6 to 3.5 and 3.4. The following piece of code prints one line every second, as expected, on 3.6 and 3.5, but it doesn't on 3.4. It looks like the signal is able to wake up the main thread from sleeping:

```
import time
import signal


def handle(signum, mask):
    print("received signal at", time.time())


signal.setitimer(signal.ITIMER_REAL, 1, 1)
signal.signal(signal.SIGALRM, handle)

for _ in range(2):
    now = time.time()
    delta = 1 - (time.time() - int(time.time()))
    time.sleep(delta)
    print(now, delta, time.time())
```

If I remove the timer, then everything works as expected on 3.4.

Here is some sample output from 3.6:

```
1510913832.4726589 0.5273411273956299 1510913833.000339
received signal at 1510913833.477888
1510913833.000449 0.9995510578155518 1510913834.000187
```

And some from 3.4:

```
1510913813.525479 0.4745209217071533 1510913814.004106
received signal at 1510913814.529313
1510913814.004233 0.9957659244537354 1510913814.529413
```
History
Date User Action Args
2017-11-17 10:17:40Bogdan Popasetrecipients: + Bogdan Popa
2017-11-17 10:17:40Bogdan Popasetmessageid: <1510913860.03.0.213398074469.issue32057@psf.upfronthosting.co.za>
2017-11-17 10:17:39Bogdan Popalinkissue32057 messages
2017-11-17 10:17:39Bogdan Popacreate