[Phpmyadmin-devel] AJAX error reporting system (catching errors)
Mohamed Ashraf
mohamed.ashraf.213 at gmail.com
Sat Jun 22 18:53:37 CEST 2013
On Sat, Jun 22, 2013 at 5:30 PM, Rouslan Placella <rouslan at placella.com> wrote:
> On 06/22/2013 11:10 AM, Mohamed Ashraf wrote:
>> On Sat, Jun 22, 2013 at 10:27 AM, Rouslan Placella <rouslan at placella.com> wrote:
>>> On 06/22/2013 01:21 AM, Mohamed Ashraf wrote:
>>>> On Saturday, June 22, 2013 at 12:49 AM, Rouslan Placella wrote:
>>>>> On 06/16/2013 12:59 PM, Mohamed Ashraf wrote:
>>>>>> On Wed, Jun 12, 2013 at 9:58 AM, Rouslan Placella
>>>>>> <rouslan at placella.com> wrote:
>>>>>>
>>>>>>> Some of my thoughts are:
>>>>>>>
>>>>>>> * Try/catch has a performance penalty
>>>>>> it is not too big as can be seen here
>>>>>> http://jsperf.com/try-catch-performance-overhead
>>>>>
>>>>> Really? On some browsers it's about 20 times slower on the very
>>>>> benchmark that you are linking to!
>>>> Really!! That is strange I tested it multiple times and everytime it
>>>> showed they are all equal in time. Which test case was 20 times slower?
>>>
>>> Opera 11 would be one of them. IE 10 is also quite bad, but by a lower
>>> magnitude...
>>
>> the reduction in performance is usually in wrapping the inside of a
>> function with try and catch. I was thinking of doing the other way and
>> wrapping the functions from outside like this
>>
>> var temp = PMA_foo
>> PMA_foo = function() {
>> try{
>> temp.apply(window, arguments);
>> } catch(e) {
>> my_method(e);
>> }
>> }
>>
>> I am thinking of doing this to all global functions starting with PMA_
>> and according to the benchmark this should have an equivalent
>> performance to the no try catch performance. also if we don't do
>> anything of the sort then we would never get a stacktrace.
>>
>> the javascript in phpmyadmin is just for aesthetics and caching but it
>> is not really very processor intensive anyway it is mostly about doing
>> things to the page and sending requests to the server and most of the
>> heavy lifting is done by jquery itself which I shall not change. The
>> benchmark is to show what happens in the extreme case which may be
>> problematic in node.js where the js code does heavy lifting and
>> performance hits are problematic. however for the simple javascript we
>> have, the negligible loss in performance cannot be perceived by the
>> end users. but the stack traces we get could significantly better
>> their experience in the long run.
>>
>> I will be using an automated function to add the try and catch at
>> runtime so that there would be minimum modification to the codebase
>> and it can be easily removed if required.
>>
>>>
>>>>>>> * We need to be able to easily turn off the error reporting feature
>>>>>> You can do it simply by setting a config option I have already set it
>>>>>> up in the Header.class.php
>>>>>>> * Some/most function names in the stack trace are going to be useless as
>>>>>>> the production js code is minified.
>>>>>>> * The line numbers in the file will not be of much help either, I guess,
>>>>>>> unless we change the way that the files are minified (like forcing line
>>>>>>> breaks every few hundred characters).
>>>>>> since uglified js provides little to no information about the location
>>>>>> of the error. what should we do. I checked up on source maps however
>>>>>> the browser support is not enough. so what do you think should happen.
>>>>>> I think the only way to go is to add try and catch to all the
>>>>>> different functions if you need to find out where the error has
>>>>>> occured. however adding try and catch statements to the entire
>>>>>> codebase will decrease code readability considerably.
>
> Thank you for the explanation, it makes perfect sense. By the way, in
> the above code snippet, to retain the correct context, it should be:
>
> temp.apply(this, arguments);
Ah yes you are correct. I was thinking about how will I get the
context and just assumed window. but you are correct "this" will refer
to the correct context. there is a problem with this approach since
these functions are only a small subset of the global functions used
by phpmyadmin.
>
> Also, out of curiosity, would it be possible to use such a solution for
> the event handlers that we register with AJAX.registerOnload?
> What about jquery event handlers (e.g: $('#foo').click(somefunction) ) and jquery
> ajax callbacks?
sadly no since they are anonymous functions mostly and I do not have
access to them unless I manually insert a try and catch in the code
itself
also keep in mind this is just to get the most out of the error and as
much as we do will still have exceptions that are thrown in parts of
code that are not surrounded by try and catch statements and that is
ok since there is a second line of defense with the "window.onerror".
I am just trying to catch most errors without changing alot of the
codebase and anything not caught we will still get an error report but
just without a stacktrace. Also you should keep in mind that a
stacktrace is not available in some browsers so even try and catch may
not do any better than window.error
>
> Bye,
> Rouslan
>
>
> ------------------------------------------------------------------------------
> This SF.net email is sponsored by Windows:
>
> Build for Windows Store.
>
> http://p.sf.net/sfu/windows-dev2dev
> _______________________________________________
> Phpmyadmin-devel mailing list
> Phpmyadmin-devel at lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/phpmyadmin-devel
>
More information about the Developers
mailing list