Ticket #5257 (closed defect: fixed)

Opened 4 years ago

Last modified 4 years ago

[with patch, positive review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors

Reported by: jason Owned by: mhansen
Priority: major Milestone: sage-3.3
Component: notebook Keywords:
Cc: Work issues:
Report Upstream: Reviewers:
Authors: Merged in:
Dependencies: Stopgaps:

Description

In the browser, I get:

Internal Server Error
An error occurred rendering the requested page. More information is available in the server log.

and I get a traceback as well:

2009-02-13 12:39:32-0600 [HTTPChannel,101,127.0.0.1] Exception rendering:
2009-02-13 12:39:32-0600 [HTTPChannel,101,127.0.0.1] Unhandled Error
	Traceback (most recent call last):
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/internet/defer.py", line 186, in addCallbacks
	    self._runCallbacks()
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/internet/defer.py", line 328, in _runCallbacks
	    self.result = callback(self.result, *args, **kw)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/internet/defer.py", line 289, in _continue
	    self.unpause()
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/internet/defer.py", line 285, in unpause
	    self._runCallbacks()
	--- <exception caught here> ---
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/internet/defer.py", line 328, in _runCallbacks
	    self.result = callback(self.result, *args, **kw)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/web2/server.py", line 296, in <lambda>
	    d.addCallback(lambda res, req: res.renderHTTP(req), self)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/web2/resource.py", line 85, in renderHTTP
	    return method(request)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/web2/resource.py", line 202, in http_GET
	    return super(Resource, self).http_GET(request)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/Twisted-8.1.0-py2.5-linux-i686.egg/twisted/web2/resource.py", line 128, in http_GET
	    return self.render(request)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/sage/server/notebook/twist.py", line 1633, in render
	    s = notebook.user_history_html(self.username)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/sage/server/notebook/notebook.py", line 842, in user_history_html
	    """%(username, self.html_worksheet_list_top(username, actions=False), t)
	  File "/home/grout/sage/local/lib/python2.5/site-packages/sage/server/notebook/notebook.py", line 1318, in html_worksheet_list_top
	    s += self.html_new_or_upload()
	exceptions.AttributeError: 'Notebook' object has no attribute 'html_new_or_upload'

Attachments

trac_5257.patch Download (9.3 KB) - added by mhansen 4 years ago.

Change History

comment:1 Changed 4 years ago by mabshoff

  • Milestone changed from sage-3.4.1 to sage-3.3

If humanly possible this should be fixed in 3.3.

Cheers,

Michael

comment:2 Changed 4 years ago by mhansen

  • Owner changed from boothby to mhansen
  • Status changed from new to assigned
  • Summary changed from Clicking on "Log" in the notebook (bringing you to the /history page) gives errors to [with patch, needs review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors

The following patch replace the user_history_html function with a templated version. With this removed, there were a number of unused html_* methods that could be removed. Additionally, I got rid unified list_top.html and list_top_public.html by moving all the worksheet listing specific stuff to worksheet_listing.html.

I tested this patch out pretty thoroughly and everything seems to be behaving correctly. I'll also add a test to my Selenium suite to test this in the future.

comment:3 Changed 4 years ago by mabshoff

  • Summary changed from [with patch, needs review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors to [with patch, needs rebase] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors

The patch looks good, but it needs to be rebased against 3.3.rc1 once it is out:

mabshoff@sage:/scratch/mabshoff/sage-3.3.rc1/devel/sage$ patch -p1 --dry-run < trac_5257.patch 
patching file sage/server/notebook/notebook.py
Reversed (or previously applied) patch detected!  Assume -R? [n] Y
Apply anyway? [n] Y
Skipping patch.
3 out of 3 hunks ignored -- saving rejects to file sage/server/notebook/notebook.py.rej
patching file sage/server/notebook/templates/history.html
patching file sage/server/notebook/templates/list_top.html
patching file sage/server/notebook/templates/list_top_public.html
patching file sage/server/notebook/templates/worksheet_listing.html
patching file sage/server/notebook/twist.py

Cheers,

Michael

Changed 4 years ago by mhansen

comment:4 Changed 4 years ago by mhansen

  • Summary changed from [with patch, needs rebase] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors to [with patch, needs review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors

I've posted a rebased patch against 3.3.rc1.

comment:5 Changed 4 years ago by mabshoff

  • Summary changed from [with patch, needs review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors to [with patch, positive review] Clicking on "Log" in the notebook (bringing you to the /history page) gives errors

Looks good to me and fixes the bug in question. I am somewhat relying on Mike's automated testing here.

Cheers,

Michael

comment:6 Changed 4 years ago by mabshoff

  • Status changed from assigned to closed
  • Resolution set to fixed

Merged in Sage 3.3.rc3.

Cheers,

Michael

Note: See TracTickets for help on using tickets.