Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
dd08c570
Commit
dd08c570
authored
Jul 23, 2016
by
Hanno Schlichting
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove `Control_Panel/DebugInfo`.
parent
c0447b1f
Changes
5
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
44 additions
and
504 deletions
+44
-504
CHANGES.rst
CHANGES.rst
+2
-0
src/App/ApplicationManager.py
src/App/ApplicationManager.py
+13
-141
src/App/dtml/cpContents.dtml
src/App/dtml/cpContents.dtml
+0
-26
src/App/dtml/debug.dtml
src/App/dtml/debug.dtml
+0
-117
src/App/tests/test_ApplicationManager.py
src/App/tests/test_ApplicationManager.py
+29
-220
No files found.
CHANGES.rst
View file @
dd08c570
...
...
@@ -21,6 +21,8 @@ Features Added
Restructuring
+++++++++++++
- Remove `Control_Panel/DebugInfo`.
- Remove profiling support via `publisher-profile-file` directive.
- Create new `Products.Sessions` distribution including Products.Sessions
...
...
src/App/ApplicationManager.py
View file @
dd08c570
...
...
@@ -11,7 +11,6 @@
#
##############################################################################
from
cStringIO
import
StringIO
from
logging
import
getLogger
import
os
import
sys
...
...
@@ -26,15 +25,12 @@ from App.CacheManager import CacheManager
from
App.config
import
getConfiguration
from
App.DavLockManager
import
DavLockManager
from
App.special_dtml
import
DTMLFile
from
App.Undo
import
UndoSupport
from
App.version_txt
import
version_txt
from
DateTime.DateTime
import
DateTime
from
OFS.Folder
import
Folder
from
OFS.SimpleItem
import
Item
from
OFS.SimpleItem
import
SimpleItem
from
Products.PageTemplates.PageTemplateFile
import
PageTemplateFile
from
zExceptions
import
Redirect
from
ZPublisher
import
Publish
LOG
=
getLogger
(
'ApplicationManager'
)
...
...
@@ -48,11 +44,11 @@ class DatabaseManager(Item, Implicit):
name
=
title
=
'Database Management'
meta_type
=
'Database Management'
manage_options
=
((
{
'label'
:
'Database'
,
'action'
:
'manage_main'
},
{
'label'
:
'Activity'
,
'action'
:
'manage_activity'
},
{
'label'
:
'Cache Parameters'
,
'action'
:
'manage_cacheParameters'
},
{
'label'
:
'Flush Cache'
,
'action'
:
'manage_cacheGC'
},
manage_options
=
((
{
'label'
:
'Database'
,
'action'
:
'manage_main'
},
{
'label'
:
'Activity'
,
'action'
:
'manage_activity'
},
{
'label'
:
'Cache Parameters'
,
'action'
:
'manage_cacheParameters'
},
{
'label'
:
'Flush Cache'
,
'action'
:
'manage_cacheGC'
},
))
# These need to be here rather to make tabs work correctly. This
...
...
@@ -81,8 +77,8 @@ class DatabaseChooser(SimpleItem):
name
=
title
=
'Database Management'
isPrincipiaFolderish
=
1
manage_options
=
(
{
'label'
:
'Databases'
,
'action'
:
'manage_main'
},
manage_options
=
(
{
'label'
:
'Databases'
,
'action'
:
'manage_main'
},
)
manage_main
=
PageTemplateFile
(
'www/chooseDatabase.pt'
,
globals
())
...
...
@@ -126,103 +122,12 @@ class DatabaseChooser(SimpleItem):
InitializeClass
(
DatabaseChooser
)
# refcount snapshot info
_v_rcs
=
None
_v_rst
=
None
class
DebugManager
(
Item
,
Implicit
):
""" Debug and profiling information
"""
manage
=
manage_main
=
DTMLFile
(
'dtml/debug'
,
globals
())
manage_main
.
_setName
(
'manage_main'
)
id
=
'DebugInfo'
name
=
title
=
'Debug Information'
meta_type
=
name
manage_options
=
((
{
'label'
:
'Debugging Info'
,
'action'
:
'manage_main'
},
))
manage_debug
=
DTMLFile
(
'dtml/debug'
,
globals
())
def
refcount
(
self
,
n
=
None
,
t
=
(
type
(
Implicit
),
)):
# return class reference info
counts
=
{}
for
m
in
sys
.
modules
.
values
():
if
m
is
None
:
continue
if
'six.'
in
m
.
__name__
:
continue
for
sym
in
dir
(
m
):
ob
=
getattr
(
m
,
sym
)
if
type
(
ob
)
in
t
:
counts
[
ob
]
=
sys
.
getrefcount
(
ob
)
pairs
=
[]
for
ob
,
v
in
counts
.
items
():
if
hasattr
(
ob
,
'__module__'
):
name
=
'%s.%s'
%
(
ob
.
__module__
,
ob
.
__name__
)
else
:
name
=
'%s'
%
ob
.
__name__
pairs
.
append
((
v
,
name
))
pairs
.
sort
()
pairs
.
reverse
()
if
n
is
not
None
:
pairs
=
pairs
[:
n
]
return
pairs
def
refdict
(
self
):
counts
=
{}
for
v
,
n
in
self
.
refcount
():
counts
[
n
]
=
v
return
counts
def
rcsnapshot
(
self
):
global
_v_rcs
global
_v_rst
_v_rcs
=
self
.
refdict
()
_v_rst
=
DateTime
()
def
rcdate
(
self
):
return
_v_rst
def
rcdeltas
(
self
):
if
_v_rcs
is
None
:
self
.
rcsnapshot
()
nc
=
self
.
refdict
()
rc
=
_v_rcs
rd
=
[]
for
n
,
c
in
nc
.
items
():
try
:
prev
=
rc
.
get
(
n
,
0
)
if
c
>
prev
:
rd
.
append
((
c
-
prev
,
(
c
,
prev
,
n
)))
except
Exception
:
pass
rd
.
sort
()
rd
.
reverse
()
return
[{
'name'
:
n
[
1
][
2
],
'delta'
:
n
[
0
],
'pc'
:
n
[
1
][
1
],
'rc'
:
n
[
1
][
0
],
}
for
n
in
rd
]
def
dbconnections
(
self
):
import
Zope2
# for data
return
Zope2
.
DB
.
connectionDebugInfo
()
def
manage_getSysPath
(
self
):
return
list
(
sys
.
path
)
InitializeClass
(
DebugManager
)
class
ApplicationManager
(
Folder
,
CacheManager
):
"""System management
"""
__roles__
=
(
'Manager'
,)
isPrincipiaFolderish
=
1
Database
=
DatabaseChooser
(
'Database'
)
# DatabaseManager()
DebugInfo
=
DebugManager
()
DavLocks
=
DavLockManager
()
manage
=
manage_main
=
DTMLFile
(
'dtml/cpContents'
,
globals
())
...
...
@@ -233,8 +138,6 @@ class ApplicationManager(Folder, CacheManager):
'meta_type'
:
Database
.
meta_type
},
{
'id'
:
'DavLocks'
,
'meta_type'
:
DavLocks
.
meta_type
},
{
'id'
:
'DebugInfo'
,
'meta_type'
:
DebugInfo
.
meta_type
},
)
manage_options
=
({
'label'
:
'Control Panel'
,
'action'
:
'manage_main'
},
)
...
...
@@ -273,23 +176,7 @@ class ApplicationManager(Folder, CacheManager):
def
manage_app
(
self
,
URL2
):
"""Return to the main management screen"""
raise
Redirect
,
URL2
+
'/manage'
def
process_time
(
self
,
_when
=
None
):
if
_when
is
None
:
_when
=
time
.
time
()
s
=
int
(
_when
)
-
self
.
process_start
d
=
int
(
s
/
86400
)
s
=
s
-
(
d
*
86400
)
h
=
int
(
s
/
3600
)
s
=
s
-
(
h
*
3600
)
m
=
int
(
s
/
60
)
s
=
s
-
(
m
*
60
)
d
=
d
and
(
'%d day%s'
%
(
d
,
(
d
!=
1
and
's'
or
''
)))
or
''
h
=
h
and
(
'%d hour%s'
%
(
h
,
(
h
!=
1
and
's'
or
''
)))
or
''
m
=
m
and
(
'%d min'
%
m
)
or
''
s
=
'%d sec'
%
s
return
'%s %s %s %s'
%
(
d
,
h
,
m
,
s
)
raise
Redirect
(
URL2
+
'/manage'
)
def
thread_get_ident
(
self
):
return
get_ident
()
...
...
@@ -299,12 +186,12 @@ class ApplicationManager(Folder, CacheManager):
def
db_size
(
self
):
s
=
self
.
_p_jar
.
db
().
getSize
()
if
type
(
s
)
is
type
(
''
):
if
isinstance
(
s
,
str
):
return
s
if
s
>=
1048576.0
:
return
'%.1fM'
%
(
s
/
1048576.0
)
return
'%.1fK'
%
(
s
/
1024.0
)
return
'%.1fM'
%
(
s
/
1048576.0
)
return
'%.1fK'
%
(
s
/
1024.0
)
@
requestmethod
(
'POST'
)
def
manage_pack
(
self
,
days
=
0
,
REQUEST
=
None
,
_when
=
None
):
...
...
@@ -328,21 +215,6 @@ class ApplicationManager(Folder, CacheManager):
def
getCLIENT_HOME
(
self
):
return
getConfiguration
().
clienthome
def
getServers
(
self
):
# used only for display purposes
# return a sequence of two-tuples. The first element of
# each tuple is the service name, the second is a string repr. of
# the port/socket/other on which it listens
from
asyncore
import
socket_map
l
=
[]
for
k
,
v
in
socket_map
.
items
():
# this is only an approximation
if
hasattr
(
v
,
'port'
):
type
=
str
(
getattr
(
v
,
'__class__'
,
'unknown'
))
port
=
v
.
port
l
.
append
((
str
(
type
),
'Port: %s'
%
port
))
return
l
class
AltDatabaseManager
(
DatabaseManager
,
CacheManager
):
""" Database management DBTab-style
...
...
src/App/dtml/cpContents.dtml
View file @
dd08c570
...
...
@@ -67,20 +67,6 @@ The Control Panel provides access to system information.
</div>
</td>
</tr>
<tr>
<td align="left" valign="top">
<div class="form-label">
Network Services
</div>
</td>
<td align="left" valign="top">
<div class="form-text">
<dtml-in getServers>
&dtml-sequence-key; (&dtml-sequence-item;)<br />
</dtml-in>
</div>
</td>
</tr>
<tr>
<td align="left" valign="top">
<div class="form-label">
...
...
@@ -93,18 +79,6 @@ The Control Panel provides access to system information.
</div>
</td>
</tr>
<tr>
<td align="left" valign="top">
<div class="form-label">
Running For
</div>
</td>
<td align="left" valign="top">
<div class="form-text">
&dtml-process_time;
</div>
</td>
</tr>
</table>
</form>
...
...
src/App/dtml/debug.dtml
deleted
100644 → 0
View file @
c0447b1f
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
<html>
<head>
<title><dtml-if
title
>
&dtml-title;
</dtml-if></title>
<link
rel=
"stylesheet"
type=
"text/css"
href=
"&dtml-BASEPATH1;/manage_page_style.css"
>
<dtml-if
debug_auto_reload
>
<meta
HTTP-EQUIV=
"Refresh"
CONTENT=
"&dtml-debug_auto_reload;;URL=&dtml-URL;?debug_auto_reload=&dtml-debug_auto_reload;"
>
</dtml-if>
<style
type=
"text/css"
>
<!
--
.header
{
font-weight
:
bold
;
font-size
:
10pt
;
}
.cell
{
font-size
:
10pt
;
}
--
>
</style>
</head>
<body
bgcolor=
"#ffffff"
link=
"#000099"
alink=
"#000099"
vlink=
"#000099"
>
<font
face=
"verdana, helvetica, sans-serif"
size=
"2"
color=
"#333333"
>
<dtml-var
manage_tabs
>
<dtml-if
update_snapshot
>
<dtml-call
rcsnapshot
>
</dtml-if>
<h3>
Debug Information
</h3>
<form
action=
"&dtml-URL;"
method=
"GET"
>
<p>
<ul>
<li>
Zope version:
&dtml-version_txt;
<li>
Python version:
&dtml-sys_version;
<li>
System Platform:
&dtml-sys_platform;
<li>
INSTANCE_HOME:
&dtml-getINSTANCE_HOME;
<li>
CLIENT_HOME:
&dtml-getCLIENT_HOME;
<li>
Process ID:
&dtml-process_id;
(
&dtml-thread_get_ident;
)
<li>
Running for:
&dtml-process_time;
<li>
sys.path:
<dtml-in
manage_getSysPath
><br
/>
&dtml-sequence-item;
</dtml-in>
<li>
Top Refcounts:
<br><select
name=
"foo"
size=
"5"
><dtml-in
"
refcount
(
100
)"
><option>
&dtml-sequence-item;
:
&dtml-sequence-key;
</option></dtml-in
></select><br><br>
<table
border=
"1"
>
<dtml-in
rcdeltas
mapping
>
<dtml-if
sequence-start
>
<tr>
<th
class=
"header"
align=
"left"
valign=
"top"
>
Class
</th>
<th
class=
"header"
align=
"left"
valign=
"top"
>
<dtml-var
rcdate
fmt=
"fCommon"
null=
""
>
</th>
<th
class=
"header"
align=
"left"
valign=
"top"
>
<dtml-var
ZopeTime
fmt=
"fCommon"
>
</th>
<th
class=
"header"
align=
"left"
valign=
"top"
>
Delta
</th>
</tr>
</dtml-if>
<tr>
<td
class=
"cell"
align=
"left"
valign=
"top"
>
&dtml-name;
</td>
<td
class=
"cell"
align=
"left"
valign=
"top"
>
&dtml-pc;
</td>
<td
class=
"cell"
align=
"left"
valign=
"top"
>
&dtml-rc;
</td>
<td
class=
"cell"
align=
"left"
valign=
"top"
>
+
&dtml-delta;
</td>
</tr>
</dtml-in>
</table>
<p><a
href=
"../Database/cache_detail"
>
Cache detail
</a>
|
<a
href=
"../Database/cache_extreme_detail"
>
Cache extreme detail
</a>
</p>
<p><a
href=
"&dtml-URL;?update_snapshot=1"
>
Update Snapshot
</a>
|
<dtml-if
debug_auto_reload
>
<a
href=
"&dtml-URL;"
>
Stop auto refresh
</a>
<dtml-else>
<a
href=
"&dtml-URL;"
>
Refresh
</a>
|
Auto refresh interval (seconds):
<input
type=
"text"
name=
"debug_auto_reload"
size=
"3"
value=
"10"
>
<input
type=
"submit"
value=
"Start auto refresh"
>
</dtml-if>
</p>
<li>
Connections:
<table
border=
"1"
>
<tr><th>
opened
</th><th>
info
</th></tr>
<dtml-in
dbconnections
mapping
>
<tr><td>
&dtml-opened;
</td><td>
&dtml-info;
</td></tr>
</dtml-in></table>
</ul>
</p>
</form>
<dtml-var
manage_page_footer
>
src/App/tests/test_ApplicationManager.py
View file @
dd08c570
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment