Commit 58ba7a98e028f35c4084c8aef0164a64a7c517d7

Authored by Augusto Herrmann
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
LEIAME 0 → 100644
  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,
app/barrabrasil.py 0 → 100644
  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)
app/static/estilo-barra.css 0 → 100644
  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 +}
assets/barra-brasil.coffee 0 → 100644
  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
assets/conteudo-barra.html 0 → 100644
  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
assets/estilo-barra.scss 0 → 100644
  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 +}
assets/google-analytics.coffee 0 → 100644
  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 +)()
assets/imagens/ai.png 0 → 100644

5.58 KB

assets/imagens/barra-brasil-v3-bgx.gif 0 → 100644

43 Bytes

assets/imagens/barra-brasil-v3-bgx.png 0 → 100644

183 Bytes

assets/imagens/brasil.png 0 → 100644

5.6 KB

barra-brasil-1.yaml 0 → 100644
  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
barra-brasil-2.yaml 0 → 100644
  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
doc/fluxo-de-compilacao.png 0 → 100644

47.2 KB

test/Teste de stress.jmx 0 → 100644
  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>