Commit 58ba7a98e028f35c4084c8aef0164a64a7c517d7
0 parents
Exists in
master
Corre??o: removido o c?digo do arquivo de template HTML e acrescentado o c?digo …
…do Google Analytics em CoffeeScript
Showing
15 changed files
with
447 additions
and
0 deletions
Show diff stats
1 | +++ a/LEIAME | ||
@@ -0,0 +1,34 @@ | @@ -0,0 +1,34 @@ | ||
1 | +Projeto Barra Brasil Distribuída - Desenvolvimento | ||
2 | + | ||
3 | +Como instalar | ||
4 | + | ||
5 | +Dependências: | ||
6 | + | ||
7 | + - Flask | ||
8 | + - assetgen | ||
9 | + - node.js | ||
10 | + - coffeescript | ||
11 | + - sass | ||
12 | + | ||
13 | +Requisitos da Barra | ||
14 | + | ||
15 | +1. A Barra deve ser adaptável a um desenho fluído e fixo | ||
16 | +2. A Barra deve suportar diferentes opções de cor de fundo | ||
17 | +3. A Barra deve suportar a inclusão dinâmica do nome da organização | ||
18 | +4. A Barra deve funcionar nos navegadores: | ||
19 | + Internet Explorer versão 8 ou superior | ||
20 | + Mozilla Firefox versão | ||
21 | + Google Chrome versão | ||
22 | + Safari versão | ||
23 | + Opera versão | ||
24 | + Navegadores de dispositivos móveis | ||
25 | + | ||
26 | +5. A Barra deve degradar graciosamente (graceful degradation ou progressive enhancement) clientes que não possuam compatibilidade ou no qual o javascript esteja desligado | ||
27 | + | ||
28 | +6. A barra deve ser acessível | ||
29 | + | ||
30 | +Considerações sobre a arquitetura | ||
31 | + | ||
32 | +1. A barra será hospedada em local centralizado e chamada de forma distribuída pelos portais institucionais | ||
33 | + | ||
34 | +2. A barra será incluída via javascript minificado, |
1 | +++ a/app/barrabrasil.py | ||
@@ -0,0 +1,42 @@ | @@ -0,0 +1,42 @@ | ||
1 | +from flask import Flask, url_for, render_template, request, Response, make_response | ||
2 | +import hashlib | ||
3 | +app = Flask(__name__) | ||
4 | + | ||
5 | +@app.route('/') | ||
6 | +def pagina_teste(): | ||
7 | + # apos o desenvolvimento substituir por redirect para e-pwg | ||
8 | + bootstrap = ''' | ||
9 | + <html> | ||
10 | + <head></head> | ||
11 | + <body> | ||
12 | + <div id="barra-brasil"><a href="http://brasil.gov.br" style="background:#7F7F7F; height: 20px; padding:4px 0 4px 10px; display: block; font-family:sans,sans-serif; text-decoration:none; color:white; ">Portal do Governo Brasileiro</a></div> | ||
13 | + <script src="barra.js?cor=verde" type="text/javascript"></script> | ||
14 | + </body> | ||
15 | + </html> | ||
16 | + ''' | ||
17 | + return bootstrap # % url_for('static', filename='barra-brasil.js') | ||
18 | + | ||
19 | +@app.route('/barra.js') | ||
20 | +def barra(): | ||
21 | + nome_cor = request.args.get('cor', 'azul') | ||
22 | + paleta = { | ||
23 | + 'azul': '#004B82', | ||
24 | + 'preta': '#000000', | ||
25 | + 'cinza': '#7F7F7F', | ||
26 | + 'verde': '#00500F', | ||
27 | + } | ||
28 | + cor = paleta.get(nome_cor, '#004B82') | ||
29 | + conteudo = render_template('barra-brasil.js', cor=cor) | ||
30 | + etag = hashlib.sha1(conteudo.encode('utf-8')).hexdigest() | ||
31 | + if request.if_none_match and \ | ||
32 | + etag in request.if_none_match: | ||
33 | + resposta = Response(status=304) | ||
34 | + else: # nao esta em cache do navegador | ||
35 | + resposta = make_response(conteudo) | ||
36 | + resposta.set_etag(etag) | ||
37 | + resposta.headers['Content-type'] = 'application/javascript' | ||
38 | + resposta.headers['Cache-control'] = 'max-age: 3600' | ||
39 | + return resposta | ||
40 | + | ||
41 | +if __name__ == '__main__': | ||
42 | + app.run(debug=True) |
1 | +++ a/app/static/estilo-barra.css | ||
@@ -0,0 +1,64 @@ | @@ -0,0 +1,64 @@ | ||
1 | +/* http://meyerweb.com/eric/tools/css/reset/ | ||
2 | + v2.0 | 20110126 | ||
3 | + License: none (public domain) | ||
4 | +*/ | ||
5 | + | ||
6 | + | ||
7 | +#barra-brasil div, #barra-brasil a, #barra-brasil ul, #barra-brasil li{ | ||
8 | + margin: 0; | ||
9 | + padding: 0; | ||
10 | + border: 0; | ||
11 | + font-size: 100%; | ||
12 | + font-family: inherit; | ||
13 | + vertical-align: baseline; | ||
14 | +} | ||
15 | + | ||
16 | +body { | ||
17 | + line-height: 1; | ||
18 | +} | ||
19 | +#barra-brasil ul { | ||
20 | + list-style: none; | ||
21 | +} | ||
22 | + | ||
23 | +/* Ministerio do Planejamento */ | ||
24 | + | ||
25 | +#barra-brasil { | ||
26 | + position:relative; | ||
27 | + overflow:hidden; | ||
28 | + min-width:1000px; | ||
29 | + background: #7F7F7F url("") center bottom no-repeat; | ||
30 | +} | ||
31 | + | ||
32 | +#barra-brasil .barra { | ||
33 | + display: block; | ||
34 | + width: 960px; | ||
35 | + height:28px; | ||
36 | + margin: 0 auto; | ||
37 | + background: url("") 0 bottom repeat-x; | ||
38 | +} | ||
39 | + | ||
40 | +#barra-brasil .barra ul { | ||
41 | + float:right; | ||
42 | + width: 319px; | ||
43 | +} | ||
44 | + | ||
45 | +#barra-brasil .barra ul li { | ||
46 | + float: left; | ||
47 | + padding-left: 25px; | ||
48 | +} | ||
49 | + | ||
50 | +#barra-brasil .ai { | ||
51 | + display: block; | ||
52 | + width: 161px; | ||
53 | + height: 28px; | ||
54 | + text-indent: -99999px; | ||
55 | + background: #7F7F7F url("") no-repeat 0 4px; | ||
56 | +} | ||
57 | + | ||
58 | +#barra-brasil .brasilgov { | ||
59 | + display: block; | ||
60 | + width: 108px; | ||
61 | + height: 28px; | ||
62 | + text-indent: -99999px; | ||
63 | + background: #7F7F7F url("") no-repeat 0 4px; | ||
64 | +} |
1 | +++ a/assets/barra-brasil.coffee | ||
@@ -0,0 +1,22 @@ | @@ -0,0 +1,22 @@ | ||
1 | + divBarra = document.getElementById("barra-brasil") | ||
2 | + head = document.getElementsByTagName("head")[0] | ||
3 | + link = document.createElement("link") | ||
4 | + href = document.createAttribute("href") | ||
5 | + | ||
6 | + # src.nodeValue = "http://barra.brasil.gov.br/estilo-barra.css"; | ||
7 | + # href.nodeValue = "http://189.9.137.173/estilo-barra.css"; | ||
8 | + # href.nodeValue = "static/estilo-barra.css" | ||
9 | + window._barrabrasil = | ||
10 | + insere_css: (css) -> | ||
11 | + style = document.createElement("style") | ||
12 | + tipo = document.createAttribute("type") | ||
13 | + tipo.nodeValue = "text/css" | ||
14 | + media = document.createAttribute("media") | ||
15 | + media.nodeValue = "all" | ||
16 | + conteudo = document.createTextNode(css) | ||
17 | + style.setAttributeNode tipo | ||
18 | + style.setAttributeNode media | ||
19 | + style.appendChild conteudo | ||
20 | + head.appendChild style | ||
21 | + | ||
22 | + divBarra.innerHTML = conteudoBarra |
1 | +++ a/assets/conteudo-barra.html | ||
@@ -0,0 +1 @@ | @@ -0,0 +1 @@ | ||
1 | +<div class="barra"><ul><li><a href="http://www.acessoainformacao.gov.br" class="ai" title="Acesso à informação">www.sic.gov.br</a></li><li><a href="http://www.brasil.gov.br" class="brasilgov" title="Portal de Estado do Brasil">www.brasil.gov.br</a></li></ul></div> | ||
0 | \ No newline at end of file | 2 | \ No newline at end of file |
1 | +++ a/assets/estilo-barra.scss | ||
@@ -0,0 +1,62 @@ | @@ -0,0 +1,62 @@ | ||
1 | +/* http://meyerweb.com/eric/tools/css/reset/ | ||
2 | + v2.0 | 20110126 | ||
3 | + License: none (public domain) | ||
4 | +*/ | ||
5 | + | ||
6 | +#barra-brasil { | ||
7 | + div, a, ul, li { | ||
8 | + margin: 0; | ||
9 | + padding: 0; | ||
10 | + border: 0; | ||
11 | + font-size: 100%; | ||
12 | + font-family: inherit; | ||
13 | + vertical-align: baseline; | ||
14 | + } | ||
15 | +} | ||
16 | + | ||
17 | +body { | ||
18 | + line-height: 1; | ||
19 | +} | ||
20 | + | ||
21 | +#barra-brasil ul { | ||
22 | + list-style: none; | ||
23 | +} | ||
24 | + | ||
25 | +/* Ministerio do Planejamento */ | ||
26 | + | ||
27 | +#barra-brasil { | ||
28 | + position: relative; | ||
29 | + overflow: hidden; | ||
30 | + min-width: 1000px; | ||
31 | + $cor: \{\{ cor \}\}; | ||
32 | + background: $cor embed("imagens/barra-brasil-v3-bgx.png") center bottom no-repeat; | ||
33 | + .barra { | ||
34 | + display: block; | ||
35 | + width: 960px; | ||
36 | + height: 28px; | ||
37 | + margin: 0 auto; | ||
38 | + background: embed("imagens/barra-brasil-v3-bgx.gif") 0 bottom repeat-x; | ||
39 | + ul { | ||
40 | + float: right; | ||
41 | + width: 319px; | ||
42 | + li { | ||
43 | + float: left; | ||
44 | + padding-left: 25px; | ||
45 | + } | ||
46 | + } | ||
47 | + } | ||
48 | + .ai { | ||
49 | + display: block; | ||
50 | + width: 161px; | ||
51 | + height: 28px; | ||
52 | + text-indent: -99999px; | ||
53 | + background: $cor embed("imagens/ai.png") no-repeat 0 4px; | ||
54 | + } | ||
55 | + .brasilgov { | ||
56 | + display: block; | ||
57 | + width: 108px; | ||
58 | + height: 28px; | ||
59 | + text-indent: -99999px; | ||
60 | + background: $cor embed("imagens/brasil.png") no-repeat 0 4px; | ||
61 | + } | ||
62 | +} |
1 | +++ a/assets/google-analytics.coffee | ||
@@ -0,0 +1,12 @@ | @@ -0,0 +1,12 @@ | ||
1 | +_gaq = _gaq or [] | ||
2 | +_gaq.push ["_setAccount", "UA-37670561-1"] | ||
3 | +_gaq.push ["_setDomainName", "gov.br"] | ||
4 | +_gaq.push ["_trackPageview"] | ||
5 | +(-> | ||
6 | + ga = document.createElement("script") | ||
7 | + ga.type = "text/javascript" | ||
8 | + ga.async = true | ||
9 | + ga.src = ((if "https:" is document.location.protocol then "https://ssl" else "http://www")) + ".google-analytics.com/ga.js" | ||
10 | + s = document.getElementsByTagName("script")[0] | ||
11 | + s.parentNode.insertBefore ga, s | ||
12 | +)() |
5.58 KB
43 Bytes
183 Bytes
5.6 KB
1 | +++ a/barra-brasil-1.yaml | ||
@@ -0,0 +1,42 @@ | @@ -0,0 +1,42 @@ | ||
1 | +# configuracao do assetgen para: | ||
2 | +# - gerar o script de comportamento, minificado | ||
3 | +# - gerar o css com as imagens incorporadas | ||
4 | + | ||
5 | +generate: | ||
6 | + | ||
7 | +- barra-brasil.js: | ||
8 | + source: | ||
9 | + - assets/conteudo-barra.html | ||
10 | + - assets/barra-brasil.coffee | ||
11 | + - assets/google-analytics.coffee | ||
12 | + - raw: "})();" # fechamento do escopo da funcao anonima (ver template abaixo) | ||
13 | + template: | | ||
14 | + (function(){ | ||
15 | + var conteudoBarra = '${source|trim}'; | ||
16 | + | ||
17 | +- estilo-barra.css: | ||
18 | + source: | ||
19 | + - assets/estilo-barra.scss | ||
20 | + depends: | ||
21 | + - assets/imagens/* | ||
22 | + embed.path.root: assets | ||
23 | + embed.url.base: imagens/ | ||
24 | + | ||
25 | +- barra-brasil-css.js: | ||
26 | + source: | ||
27 | + - build/estilo-barra.css | ||
28 | + template: | | ||
29 | + window._barrabrasil.insere_css('${source|trim}'); | ||
30 | + | ||
31 | +css.embed: true | ||
32 | +css.embed.only: true | ||
33 | +css.compress: true | ||
34 | +js.compress: false | ||
35 | +js.uglify.bin: uglifyjs | ||
36 | +output.directory: build | ||
37 | +output.hashed: false | ||
38 | +output.manifest: app/assets.json | ||
39 | + | ||
40 | +profile.dev: | ||
41 | + css.compress: false | ||
42 | + js.compress: false |
1 | +++ a/barra-brasil-2.yaml | ||
@@ -0,0 +1,20 @@ | @@ -0,0 +1,20 @@ | ||
1 | +# configuracao do assetgen para: | ||
2 | +# - mesclar o css com javascript de comportamento | ||
3 | + | ||
4 | +generate: | ||
5 | + | ||
6 | +- barra-brasil.js: | ||
7 | + source: | ||
8 | + - build/barra-brasil.js # parte de comportamento | ||
9 | + - build/barra-brasil-css.js # codigo de insercao do css | ||
10 | + uglify.bin: uglifyjs | ||
11 | + | ||
12 | +css.embed: true | ||
13 | +css.embed.only: true | ||
14 | +output.directory: app/templates | ||
15 | +output.hashed: false | ||
16 | +output.manifest: assets.json | ||
17 | + | ||
18 | +profile.dev: | ||
19 | + css.compress: false | ||
20 | + js.compress: false |
47.2 KB
1 | +++ a/test/Teste de stress.jmx | ||
@@ -0,0 +1,148 @@ | @@ -0,0 +1,148 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<jmeterTestPlan version="1.2" properties="2.3" jmeter="2.8 r1393162"> | ||
3 | + <hashTree> | ||
4 | + <TestPlan guiclass="TestPlanGui" testclass="TestPlan" testname="Stress Bitch!" enabled="true"> | ||
5 | + <stringProp name="TestPlan.comments">Teste de stress genérico</stringProp> | ||
6 | + <boolProp name="TestPlan.functional_mode">false</boolProp> | ||
7 | + <boolProp name="TestPlan.serialize_threadgroups">false</boolProp> | ||
8 | + <elementProp name="TestPlan.user_defined_variables" elementType="Arguments" guiclass="ArgumentsPanel" testclass="Arguments" testname="User Defined Variables" enabled="true"> | ||
9 | + <collectionProp name="Arguments.arguments"/> | ||
10 | + </elementProp> | ||
11 | + <stringProp name="TestPlan.user_define_classpath"></stringProp> | ||
12 | + </TestPlan> | ||
13 | + <hashTree> | ||
14 | + <ThreadGroup guiclass="ThreadGroupGui" testclass="ThreadGroup" testname="Web Test" enabled="true"> | ||
15 | + <elementProp name="ThreadGroup.main_controller" elementType="LoopController" guiclass="LoopControlPanel" testclass="LoopController" testname="Loop Controller" enabled="true"> | ||
16 | + <boolProp name="LoopController.continue_forever">false</boolProp> | ||
17 | + <stringProp name="LoopController.loops">100</stringProp> | ||
18 | + </elementProp> | ||
19 | + <stringProp name="ThreadGroup.num_threads">1000</stringProp> | ||
20 | + <stringProp name="ThreadGroup.ramp_time">0</stringProp> | ||
21 | + <longProp name="ThreadGroup.start_time">1356091419000</longProp> | ||
22 | + <longProp name="ThreadGroup.end_time">1356091419000</longProp> | ||
23 | + <boolProp name="ThreadGroup.scheduler">false</boolProp> | ||
24 | + <stringProp name="ThreadGroup.on_sample_error">continue</stringProp> | ||
25 | + <stringProp name="ThreadGroup.duration"></stringProp> | ||
26 | + <stringProp name="ThreadGroup.delay"></stringProp> | ||
27 | + </ThreadGroup> | ||
28 | + <hashTree> | ||
29 | + <HTTPSamplerProxy guiclass="HttpTestSampleGui" testclass="HTTPSamplerProxy" testname="HTTP Request" enabled="true"> | ||
30 | + <elementProp name="HTTPsampler.Arguments" elementType="Arguments" guiclass="HTTPArgumentsPanel" testclass="Arguments" testname="User Defined Variables" enabled="true"> | ||
31 | + <collectionProp name="Arguments.arguments"/> | ||
32 | + </elementProp> | ||
33 | + <stringProp name="HTTPSampler.domain">barra.brasil.gov.br</stringProp> | ||
34 | + <stringProp name="HTTPSampler.port"></stringProp> | ||
35 | + <stringProp name="HTTPSampler.connect_timeout"></stringProp> | ||
36 | + <stringProp name="HTTPSampler.response_timeout"></stringProp> | ||
37 | + <stringProp name="HTTPSampler.protocol"></stringProp> | ||
38 | + <stringProp name="HTTPSampler.contentEncoding"></stringProp> | ||
39 | + <stringProp name="HTTPSampler.path"></stringProp> | ||
40 | + <stringProp name="HTTPSampler.method">GET</stringProp> | ||
41 | + <boolProp name="HTTPSampler.follow_redirects">true</boolProp> | ||
42 | + <boolProp name="HTTPSampler.auto_redirects">false</boolProp> | ||
43 | + <boolProp name="HTTPSampler.use_keepalive">true</boolProp> | ||
44 | + <boolProp name="HTTPSampler.DO_MULTIPART_POST">false</boolProp> | ||
45 | + <boolProp name="HTTPSampler.monitor">false</boolProp> | ||
46 | + <stringProp name="HTTPSampler.embedded_url_re"></stringProp> | ||
47 | + </HTTPSamplerProxy> | ||
48 | + <hashTree/> | ||
49 | + <ResultCollector guiclass="TableVisualizer" testclass="ResultCollector" testname="View Results in Table" enabled="true"> | ||
50 | + <boolProp name="ResultCollector.error_logging">false</boolProp> | ||
51 | + <objProp> | ||
52 | + <name>saveConfig</name> | ||
53 | + <value class="SampleSaveConfiguration"> | ||
54 | + <time>true</time> | ||
55 | + <latency>true</latency> | ||
56 | + <timestamp>true</timestamp> | ||
57 | + <success>true</success> | ||
58 | + <label>true</label> | ||
59 | + <code>true</code> | ||
60 | + <message>true</message> | ||
61 | + <threadName>true</threadName> | ||
62 | + <dataType>true</dataType> | ||
63 | + <encoding>false</encoding> | ||
64 | + <assertions>true</assertions> | ||
65 | + <subresults>true</subresults> | ||
66 | + <responseData>false</responseData> | ||
67 | + <samplerData>false</samplerData> | ||
68 | + <xml>true</xml> | ||
69 | + <fieldNames>false</fieldNames> | ||
70 | + <responseHeaders>false</responseHeaders> | ||
71 | + <requestHeaders>false</requestHeaders> | ||
72 | + <responseDataOnError>false</responseDataOnError> | ||
73 | + <saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage> | ||
74 | + <assertionsResultsToSave>0</assertionsResultsToSave> | ||
75 | + <bytes>true</bytes> | ||
76 | + </value> | ||
77 | + </objProp> | ||
78 | + <stringProp name="filename"></stringProp> | ||
79 | + </ResultCollector> | ||
80 | + <hashTree/> | ||
81 | + <ResultCollector guiclass="ViewResultsFullVisualizer" testclass="ResultCollector" testname="View Results Tree" enabled="true"> | ||
82 | + <boolProp name="ResultCollector.error_logging">false</boolProp> | ||
83 | + <objProp> | ||
84 | + <name>saveConfig</name> | ||
85 | + <value class="SampleSaveConfiguration"> | ||
86 | + <time>true</time> | ||
87 | + <latency>true</latency> | ||
88 | + <timestamp>true</timestamp> | ||
89 | + <success>true</success> | ||
90 | + <label>true</label> | ||
91 | + <code>true</code> | ||
92 | + <message>true</message> | ||
93 | + <threadName>true</threadName> | ||
94 | + <dataType>true</dataType> | ||
95 | + <encoding>false</encoding> | ||
96 | + <assertions>true</assertions> | ||
97 | + <subresults>true</subresults> | ||
98 | + <responseData>false</responseData> | ||
99 | + <samplerData>false</samplerData> | ||
100 | + <xml>true</xml> | ||
101 | + <fieldNames>false</fieldNames> | ||
102 | + <responseHeaders>false</responseHeaders> | ||
103 | + <requestHeaders>false</requestHeaders> | ||
104 | + <responseDataOnError>false</responseDataOnError> | ||
105 | + <saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage> | ||
106 | + <assertionsResultsToSave>0</assertionsResultsToSave> | ||
107 | + <bytes>true</bytes> | ||
108 | + </value> | ||
109 | + </objProp> | ||
110 | + <stringProp name="filename"></stringProp> | ||
111 | + </ResultCollector> | ||
112 | + <hashTree/> | ||
113 | + <ResultCollector guiclass="SummaryReport" testclass="ResultCollector" testname="Summary Report" enabled="true"> | ||
114 | + <boolProp name="ResultCollector.error_logging">false</boolProp> | ||
115 | + <objProp> | ||
116 | + <name>saveConfig</name> | ||
117 | + <value class="SampleSaveConfiguration"> | ||
118 | + <time>true</time> | ||
119 | + <latency>true</latency> | ||
120 | + <timestamp>true</timestamp> | ||
121 | + <success>true</success> | ||
122 | + <label>true</label> | ||
123 | + <code>true</code> | ||
124 | + <message>true</message> | ||
125 | + <threadName>true</threadName> | ||
126 | + <dataType>true</dataType> | ||
127 | + <encoding>false</encoding> | ||
128 | + <assertions>true</assertions> | ||
129 | + <subresults>true</subresults> | ||
130 | + <responseData>false</responseData> | ||
131 | + <samplerData>false</samplerData> | ||
132 | + <xml>true</xml> | ||
133 | + <fieldNames>false</fieldNames> | ||
134 | + <responseHeaders>false</responseHeaders> | ||
135 | + <requestHeaders>false</requestHeaders> | ||
136 | + <responseDataOnError>false</responseDataOnError> | ||
137 | + <saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage> | ||
138 | + <assertionsResultsToSave>0</assertionsResultsToSave> | ||
139 | + <bytes>true</bytes> | ||
140 | + </value> | ||
141 | + </objProp> | ||
142 | + <stringProp name="filename"></stringProp> | ||
143 | + </ResultCollector> | ||
144 | + <hashTree/> | ||
145 | + </hashTree> | ||
146 | + </hashTree> | ||
147 | + </hashTree> | ||
148 | +</jmeterTestPlan> |