I'm just as amazed by this as you are.
Just checking, you're now using the original 0.7.0b3 code,
with just this one thing disabled?
I mean, if this code is a problem why then only for your provider?
Weird, especially since the code is only useful for very rare
posts that violate Usenet standards.
Last question, which Python version are you using?
0.7.0beta3 issue: connection drops and "missing" articles
Forum rules
Help us help you:
Help us help you:
- Are you using the latest stable version of SABnzbd? Downloads page.
- Tell us what system you run SABnzbd on.
- Adhere to the forum rules.
- Do you experience problems during downloading?
Check your connection in Status and Interface settings window.
Use Test Server in Config > Servers.
We will probably ask you to do a test using only basic settings. - Do you experience problems during repair or unpacking?
Enable +Debug logging in the Status and Interface settings window and share the relevant parts of the log here using [ code ] sections.
-
- Newbie
- Posts: 9
- Joined: May 3rd, 2012, 10:18 am
Re: 0.7.0beta3 issue: connection drops and "missing" article
Yes. It's a clean install with those few lines deleted.shypike wrote:Just checking, you're now using the original 0.7.0b3 code,
with just this one thing disabled?
I know; it's weird. I've been trying various things in python this afternoon to see if I could come up with something that looked like it might be a problem. I thought it might be something to do with a trailing lf but I haven't seen anything in that regard. The reason I looked at that was the message 'server closed connection', which seemed to come up with a zero byte block read. Nothing on that front has shown up though.I mean, if this code is a problem why then only for your provider?
What's really nagging at me is that the if shouldn't even be executed in virtually all cases. But the fact that removing it makes the problem go away would seem to indicate the opposite.
This is what python reports when I start it up from the command line: Python 2.7.1+ (r271:86832, Apr 11 2011, 18:05:24). The same string is reported in the sabnzbd.log file, so no multiple installed versions by the looks of it.Last question, which Python version are you using?
Re: 0.7.0beta3 issue: connection drops and "missing" article
I'll see if can come up with some scenarios that go wrong.
Your suggestion that a zero byte result leads to the "server disconnected" message
is correct, sharp observation.
The easiest solution is to remove the feature because it's for very rare posts.
Python 2.7 should be OK.
I'll keep you posted. Thanks for your test work so far.
Your suggestion that a zero byte result leads to the "server disconnected" message
is correct, sharp observation.
The easiest solution is to remove the feature because it's for very rare posts.
Python 2.7 should be OK.
I'll keep you posted. Thanks for your test work so far.
-
- Newbie
- Posts: 9
- Joined: May 3rd, 2012, 10:18 am
Re: 0.7.0beta3 issue: connection drops and "missing" article
I think I figured it out. Shouldn't the test in the if be against self.data, not just data? Or am I missing a bigger picture (since my python skills are only slightly better than 'read it like it's C#')?
For what it's worth, I changed a clean 0.7 install to use self.data, and it works.
Code: Select all
# See if incorrect newline-only was used
# Do this as a special case to prevent using extra memory
# for normal articles
# vvvvv
if len(new_lines) == 1 and '\r' not in self.data:
new_lines = self.data.split('\n')
Re: 0.7.0beta3 issue: connection drops and "missing" article
Hangs head in deep shame
That's indeed the problem.
Yes, I did test this thing, but probably modified the code afterwards...
It probably was this first (when tested):
And I later optimized it to:
And, hey, there's no need to test this simple change, is there
It's still a riddle why it goes wrong with your provider, but it doesn't matter that much.
When the code triggers, it runs into an exception, which is caught but will result in a "server disconnected" state.
Thank you very much for your support!
[EDIT]
I suspect that your provider sometimes sends single line article chunks,
because a single line chunk will trigger the crash.
It's a very good thing that you found this, because it's very likely that this can
happen with other providers too.
That's indeed the problem.
Yes, I did test this thing, but probably modified the code afterwards...
It probably was this first (when tested):
Code: Select all
if len(new_lines) == 1:
new_lines = self.data.split('\n')
Code: Select all
if len(new_lines) == 1 and '\r' not in data:
new_lines = self.data.split('\n')
It's still a riddle why it goes wrong with your provider, but it doesn't matter that much.
When the code triggers, it runs into an exception, which is caught but will result in a "server disconnected" state.
Thank you very much for your support!
[EDIT]
I suspect that your provider sometimes sends single line article chunks,
because a single line chunk will trigger the crash.
It's a very good thing that you found this, because it's very likely that this can
happen with other providers too.
-
- Newbie
- Posts: 9
- Joined: May 3rd, 2012, 10:18 am
Re: 0.7.0beta3 issue: connection drops and "missing" article
Oh, if I only had a nickel for every time I've said that over the years (and another nickel for every time it's turned around and bit me)!shypike wrote:And, hey, there's no need to test this simple change, is there
That makes perfect sense. The 'and' is a short circuit operator, so unless it was a single line chunk the program would never get to the 'in' test.I suspect that your provider sometimes sends single line article chunks, because a single line chunk will trigger the crash.
You're more than welcome. I'm glad the mystery is solved.Thank you very much for your support!