box for other views
authorMichal Sojka <sojkam1@fel.cvut.cz>
Thu, 9 Dec 2010 13:30:20 +0000 (14:30 +0100)
committerMichal Sojka <sojkam1@fel.cvut.cz>
Thu, 9 Dec 2010 13:30:20 +0000 (14:30 +0100)
gw-tests/genhtml/genhtml-test.py
gw-tests/genhtml/genhtml.py

index cb93f32..3bdf3e3 100644 (file)
@@ -34,36 +34,36 @@ def Three_Dimensions_in_Tests():
     WVPASSEQ(pairs[4], ('DimensionKern', 'Dimension'))
     WVPASSEQ(pairs[5], ('Dimension', 'DimensionKern'))
     WVPASSEQ(len(pairs), 6)
-    WVEXCEPT(KeyError, t.addTest, None, [1, 2])
-    WVEXCEPT(KeyError, t.addTest, None, [1, 2, 3, 4])
+    WVEXCEPT(KeyError, t.addTest, None, [1, 2])
+    WVEXCEPT(KeyError, t.addTest, None, [1, 2, 3, 4])
 
-    class MyTest(Test):
-        pass
+    class MyTest(Test):
+        pass
 
-    t.addTest(MyTest, [1, 'a', 'A']);
+    t.addTest(MyTest, [1, 'a', 'A']);
 
-    WVPASSEQ(dt.keys(), [1])
-    WVPASSEQ(dk.keys(), ['a'])
-    WVPASSEQ(dd.keys(), ['A'])
+    WVPASSEQ(dt.keys(), [1])
+    WVPASSEQ(dk.keys(), ['a'])
+    WVPASSEQ(dd.keys(), ['A'])
 
-    v1 = dt[1]
-    v2 = dk['a']
-    v3 = dd['A']
+    v1 = dt[1]
+    v2 = dk['a']
+    v3 = dd['A']
 
-    WVPASSEQ(t.getTest((v1, v2, v3)), MyTest)
-    WVPASSEQ(t.getTest((v1, v3, v2)), MyTest)
-    WVPASSEQ(t.getTest((v3, v2, v1)), MyTest)
-    WVEXCEPT(KeyError, t.getTest, (v1, v1, v1))
-    WVEXCEPT(KeyError, t.getTest, (v1, v2))
-    WVEXCEPT(Exception, t.getTest, v1)
+    WVPASSEQ(t.getTest((v1, v2, v3)), MyTest)
+    WVPASSEQ(t.getTest((v1, v3, v2)), MyTest)
+    WVPASSEQ(t.getTest((v3, v2, v1)), MyTest)
+    WVEXCEPT(KeyError, t.getTest, (v1, v1, v1))
+    WVEXCEPT(KeyError, t.getTest, (v1, v2))
+    WVEXCEPT(Exception, t.getTest, v1)
 
-    WVPASSEQ([d.__class__.__name__ for d in t.space.iterRemainingDimensions([dt])], ['DimensionKern', 'Dimension']) 
-    WVPASSEQ([d.__class__.__name__ for d in t.space.iterRemainingDimensions([dt, dd])], ['DimensionKern'])
+    WVPASSEQ([d.__class__.__name__ for d in t.space.iterRemainingDimensions([dt])], ['DimensionKern', 'Dimension']) 
+    WVPASSEQ([d.__class__.__name__ for d in t.space.iterRemainingDimensions([dt, dd])], ['DimensionKern'])
 
-    WVPASSEQ(str([v for v in Space(dt, dk).iterValues()]), "[[DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'a')]]")
-    DimValue(dt, 2)
-    DimValue(dk, 'b')
-    WVPASSEQ(str([v for v in Space(dt, dk).iterValues()]), "[[DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'a')], [DimValue(Dimension(test), 2), DimValue(Dimension(gwkern), 'a')], [DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'b')], [DimValue(Dimension(test), 2), DimValue(Dimension(gwkern), 'b')]]")
+    WVPASSEQ(str([v for v in Space(dt, dk).iterValues()]), "[[DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'a')]]")
+    DimValue(dt, 2)
+    DimValue(dk, 'b')
+    WVPASSEQ(str([v for v in Space(dt, dk).iterValues()]), "[[DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'a')], [DimValue(Dimension(test), 2), DimValue(Dimension(gwkern), 'a')], [DimValue(Dimension(test), 1), DimValue(Dimension(gwkern), 'b')], [DimValue(Dimension(test), 2), DimValue(Dimension(gwkern), 'b')]]")
 
 @wvtest                
 def SpaceTests():
index 76eee7b..558ef4b 100755 (executable)
@@ -127,9 +127,10 @@ class Test:
     def isOnPath(cls, path):
        f = os.path.join(path, '.results')
        return os.path.isfile(f)
-    def __init__(self, path):
+    def __init__(self, path, values):
        self.path = path
         self.name = os.path.basename(path)
+        self.values = values
     def printThumbLink(self, file):
         thumb = self.path+'/thumb'
         try:
@@ -137,8 +138,44 @@ class Test:
         except OSError:
             imgs = [ self.name + ".png" ]
         for img in imgs:
-            print >>file, "<a href='%s/%s'><img src='%s/thumb/%s'></a>" % \
-                  (urllib.quote(self.path), img, urllib.quote(self.path), img)
+            print >>file, "<a href='%s/results.html'><img src='%s/thumb/%s'></a>" % \
+                  (urllib.quote(self.path), urllib.quote(self.path), img)
+    def generateHtml(self):
+        html = open(os.path.join(path, 'results.html'), "w")
+       print >> html, """<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
+<head>
+<meta http-equiv="content-type" content="text/html; charset=utf-8" />
+<title>%s</title>
+<link rel="stylesheet" href="style.css" type="text/css" /> 
+</head>
+<body>
+<h1>%s</h1>"""  % (title, title)
+        params = ["%s %s" % (v.dim, v) for v in self.vals]
+        print >>html, "Results for:", ", ".join(params), "<hr />"
+       for d in self.dimOther:
+            print >>html, "%s: " % d
+            print >>html, "<a href='%s'>X axis</a>, " % \
+                Page((self.dimy, d), self.valsOther - d + self.dimx.getValue(0), self.tests).getName()
+            print >>html, "<a href='%s'>Y axis</a>;&nbsp;&nbsp;" % \
+                Page((d, self.dimx), self.valsOther - d + self.dimy.getValue(0), self.tests).getName()
+            links = []
+            for v in d.values():
+                if v in self.valsOther:
+                    links.append(str(v))
+                else:
+                    vv = DimValues(self.valsOther)
+                    vv.replace(v)
+                    links.append("<a href='%s'>%s</a>"%(urllib.quote(Page((self.dimy, self.dimx), vv, self.tests).getName()), str(v)))
+            print >>html, " | ".join(links)
+            print >>html, "<br>"
+            try:
+                print >>html, d.htmlPreamble()
+            except Exception:
+                pass
+
+        
+        html.close()
 
 class Space(list):
     """List of Dimensions()s (order matters)"""
@@ -190,21 +227,20 @@ class Tests(dict):
         realkey = self.space.reorder(key)
        return self[realkey.key()]
 
-    def addTest(self, test, coordinates):
-       if len(coordinates) != len(self.space):
-           raise KeyError("The number coordinates do not match the number of dimensions: " + str(coordinates))
-       self[tuple(coordinates)] = test
-       for i in xrange(len(coordinates)):
-            DimValue(self.space[i], coordinates[i])
-
+    def addTest(self, test):
+       self[test.values.key()] = test
+       
     def populate(self, rootpath):
        for root, dirs, files in os.walk(rootpath):
            if (root.find(rootpath) == 0):
-               coordinates = root[len(rootpath):]
+               coordinates = root[len(rootpath):].split("/")
            else:
-               coordinates = rootpath
+               coordinates = rootpath.split("/")
            if Test.isOnPath(root):
-               self.addTest(Test(root), coordinates.split("/"))
+                if len(coordinates) != len(self.space):
+                    raise KeyError("The number coordinates do not match the number of dimensions: " + str(coordinates))
+                dv = DimValues([DimValue(self.space[i], coordinates[i]) for i in xrange(len(coordinates))])
+               self.addTest(Test(root, dv))
     def generateHtml(self):
        for pair in self.space.iterDimensionPairs():
            remDims = Space(*tuple([d for d in self.space.iterRemainingDimensions(pair)]))
@@ -215,6 +251,14 @@ class Tests(dict):
            os.remove("index.html")
        except OSError: pass
        os.symlink(page.getName(), "index.html")
+        css = open("style.css", "w")
+        print >>css, """img { border: 0; }
+table { border-collapse: collapse; }
+th, td { border: 1px solid lightgray; padding: 4px;}
+h4 { margin: 0; }
+.box { border: 1px solid black; padding: 1ex; margin: 1ex 0}
+"""
+        css.close()
 
        #os.system("source-highlight -d --output-dir=. ../*.sh")
 
@@ -235,16 +279,13 @@ class Page:
 <head>
 <meta http-equiv="content-type" content="text/html; charset=utf-8" />
 <title>%s</title>
-<style>
-img { border: 0; }
-table { border-collapse: collapse; }
-th, td { border: 1px solid lightgray; padding: 4px;}
-</style>
+<link rel="stylesheet" href="style.css" type="text/css" /> 
 </head>
 <body>
 <h1>%s</h1>"""  % (title, title)
         params = ["%s %s" % (v.dim, v) for v in self.valsOther]
-        print >>html, "Results for:", ", ".join(params), "<hr />"
+        print >>html, "<h3>Results for ", ", ".join(params), "</h3>"
+        print >>html, "<div class='box'><h4>Other views</h4>"
        for d in self.dimOther:
             print >>html, "%s: " % d
             print >>html, "<a href='%s'>X axis</a>, " % \
@@ -265,6 +306,7 @@ th, td { border: 1px solid lightgray; padding: 4px;}
                 print >>html, d.htmlPreamble()
             except Exception:
                 pass
+        print >>html, "</div>"
 
        print >>html, "<table><thead><tr><td>%s &rarr; <br />%s &darr;</td>" % (self.dimx.name, self.dimy.name)
        for x in self.dimx: