From 58ba7a98e028f35c4084c8aef0164a64a7c517d7 Mon Sep 17 00:00:00 2001 From: Augusto Herrmann Date: Mon, 21 Jan 2013 15:46:16 -0200 Subject: [PATCH] Corre??o: removido o c?digo do arquivo de template HTML e acrescentado o c?digo do Google Analytics em CoffeeScript --- LEIAME | 34 ++++++++++++++++++++++++++++++++++ app/barrabrasil.py | 42 ++++++++++++++++++++++++++++++++++++++++++ app/static/estilo-barra.css | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ assets/barra-brasil.coffee | 22 ++++++++++++++++++++++ assets/conteudo-barra.html | 1 + assets/estilo-barra.scss | 62 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ assets/google-analytics.coffee | 12 ++++++++++++ assets/imagens/ai.png | Bin 0 -> 5715 bytes assets/imagens/barra-brasil-v3-bgx.gif | Bin 0 -> 43 bytes assets/imagens/barra-brasil-v3-bgx.png | Bin 0 -> 183 bytes assets/imagens/brasil.png | Bin 0 -> 5737 bytes barra-brasil-1.yaml | 42 ++++++++++++++++++++++++++++++++++++++++++ barra-brasil-2.yaml | 20 ++++++++++++++++++++ doc/fluxo-de-compilacao.png | Bin 0 -> 48316 bytes test/Teste de stress.jmx | 148 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 15 files changed, 447 insertions(+), 0 deletions(-) create mode 100644 LEIAME create mode 100644 app/barrabrasil.py create mode 100644 app/static/estilo-barra.css create mode 100644 assets/barra-brasil.coffee create mode 100644 assets/conteudo-barra.html create mode 100644 assets/estilo-barra.scss create mode 100644 assets/google-analytics.coffee create mode 100644 assets/imagens/ai.png create mode 100644 assets/imagens/barra-brasil-v3-bgx.gif create mode 100644 assets/imagens/barra-brasil-v3-bgx.png create mode 100644 assets/imagens/brasil.png create mode 100644 barra-brasil-1.yaml create mode 100644 barra-brasil-2.yaml create mode 100644 doc/fluxo-de-compilacao.png create mode 100644 test/Teste de stress.jmx diff --git a/LEIAME b/LEIAME new file mode 100644 index 0000000..a706fa6 --- /dev/null +++ b/LEIAME @@ -0,0 +1,34 @@ +Projeto Barra Brasil Distribuída - Desenvolvimento + +Como instalar + +Dependências: + + - Flask + - assetgen + - node.js + - coffeescript + - sass + +Requisitos da Barra + +1. A Barra deve ser adaptável a um desenho fluído e fixo +2. A Barra deve suportar diferentes opções de cor de fundo +3. A Barra deve suportar a inclusão dinâmica do nome da organização +4. A Barra deve funcionar nos navegadores: + Internet Explorer versão 8 ou superior + Mozilla Firefox versão + Google Chrome versão + Safari versão + Opera versão + Navegadores de dispositivos móveis + +5. A Barra deve degradar graciosamente (graceful degradation ou progressive enhancement) clientes que não possuam compatibilidade ou no qual o javascript esteja desligado + +6. A barra deve ser acessível + +Considerações sobre a arquitetura + +1. A barra será hospedada em local centralizado e chamada de forma distribuída pelos portais institucionais + +2. A barra será incluída via javascript minificado, diff --git a/app/barrabrasil.py b/app/barrabrasil.py new file mode 100644 index 0000000..2260e4d --- /dev/null +++ b/app/barrabrasil.py @@ -0,0 +1,42 @@ +from flask import Flask, url_for, render_template, request, Response, make_response +import hashlib +app = Flask(__name__) + +@app.route('/') +def pagina_teste(): + # apos o desenvolvimento substituir por redirect para e-pwg + bootstrap = ''' + + + +
Portal do Governo Brasileiro
+ + + + ''' + return bootstrap # % url_for('static', filename='barra-brasil.js') + +@app.route('/barra.js') +def barra(): + nome_cor = request.args.get('cor', 'azul') + paleta = { + 'azul': '#004B82', + 'preta': '#000000', + 'cinza': '#7F7F7F', + 'verde': '#00500F', + } + cor = paleta.get(nome_cor, '#004B82') + conteudo = render_template('barra-brasil.js', cor=cor) + etag = hashlib.sha1(conteudo.encode('utf-8')).hexdigest() + if request.if_none_match and \ + etag in request.if_none_match: + resposta = Response(status=304) + else: # nao esta em cache do navegador + resposta = make_response(conteudo) + resposta.set_etag(etag) + resposta.headers['Content-type'] = 'application/javascript' + resposta.headers['Cache-control'] = 'max-age: 3600' + return resposta + +if __name__ == '__main__': + app.run(debug=True) diff --git a/app/static/estilo-barra.css b/app/static/estilo-barra.css new file mode 100644 index 0000000..acce76d --- /dev/null +++ b/app/static/estilo-barra.css @@ -0,0 +1,64 @@ +/* http://meyerweb.com/eric/tools/css/reset/ + v2.0 | 20110126 + License: none (public domain) +*/ + + +#barra-brasil div, #barra-brasil a, #barra-brasil ul, #barra-brasil li{ + margin: 0; + padding: 0; + border: 0; + font-size: 100%; + font-family: inherit; + vertical-align: baseline; +} + +body { + line-height: 1; +} +#barra-brasil ul { + list-style: none; +} + +/* Ministerio do Planejamento */ + +#barra-brasil { + position:relative; + overflow:hidden; + min-width:1000px; + background: #7F7F7F url("") center bottom no-repeat; +} + +#barra-brasil .barra { + display: block; + width: 960px; + height:28px; + margin: 0 auto; + background: url("") 0 bottom repeat-x; +} + +#barra-brasil .barra ul { + float:right; + width: 319px; +} + +#barra-brasil .barra ul li { + float: left; + padding-left: 25px; +} + +#barra-brasil .ai { + display: block; + width: 161px; + height: 28px; + text-indent: -99999px; + background: #7F7F7F url("") no-repeat 0 4px; +} + +#barra-brasil .brasilgov { + display: block; + width: 108px; + height: 28px; + text-indent: -99999px; + background: #7F7F7F url("") no-repeat 0 4px; +} diff --git a/assets/barra-brasil.coffee b/assets/barra-brasil.coffee new file mode 100644 index 0000000..a8fc800 --- /dev/null +++ b/assets/barra-brasil.coffee @@ -0,0 +1,22 @@ + divBarra = document.getElementById("barra-brasil") + head = document.getElementsByTagName("head")[0] + link = document.createElement("link") + href = document.createAttribute("href") + + # src.nodeValue = "http://barra.brasil.gov.br/estilo-barra.css"; + # href.nodeValue = "http://189.9.137.173/estilo-barra.css"; + # href.nodeValue = "static/estilo-barra.css" + window._barrabrasil = + insere_css: (css) -> + style = document.createElement("style") + tipo = document.createAttribute("type") + tipo.nodeValue = "text/css" + media = document.createAttribute("media") + media.nodeValue = "all" + conteudo = document.createTextNode(css) + style.setAttributeNode tipo + style.setAttributeNode media + style.appendChild conteudo + head.appendChild style + + divBarra.innerHTML = conteudoBarra diff --git a/assets/conteudo-barra.html b/assets/conteudo-barra.html new file mode 100644 index 0000000..5d4ffa4 --- /dev/null +++ b/assets/conteudo-barra.html @@ -0,0 +1 @@ +
\ No newline at end of file diff --git a/assets/estilo-barra.scss b/assets/estilo-barra.scss new file mode 100644 index 0000000..466d4eb --- /dev/null +++ b/assets/estilo-barra.scss @@ -0,0 +1,62 @@ +/* http://meyerweb.com/eric/tools/css/reset/ + v2.0 | 20110126 + License: none (public domain) +*/ + +#barra-brasil { + div, a, ul, li { + margin: 0; + padding: 0; + border: 0; + font-size: 100%; + font-family: inherit; + vertical-align: baseline; + } +} + +body { + line-height: 1; +} + +#barra-brasil ul { + list-style: none; +} + +/* Ministerio do Planejamento */ + +#barra-brasil { + position: relative; + overflow: hidden; + min-width: 1000px; + $cor: \{\{ cor \}\}; + background: $cor embed("imagens/barra-brasil-v3-bgx.png") center bottom no-repeat; + .barra { + display: block; + width: 960px; + height: 28px; + margin: 0 auto; + background: embed("imagens/barra-brasil-v3-bgx.gif") 0 bottom repeat-x; + ul { + float: right; + width: 319px; + li { + float: left; + padding-left: 25px; + } + } + } + .ai { + display: block; + width: 161px; + height: 28px; + text-indent: -99999px; + background: $cor embed("imagens/ai.png") no-repeat 0 4px; + } + .brasilgov { + display: block; + width: 108px; + height: 28px; + text-indent: -99999px; + background: $cor embed("imagens/brasil.png") no-repeat 0 4px; + } +} diff --git a/assets/google-analytics.coffee b/assets/google-analytics.coffee new file mode 100644 index 0000000..d096bcb --- /dev/null +++ b/assets/google-analytics.coffee @@ -0,0 +1,12 @@ +_gaq = _gaq or [] +_gaq.push ["_setAccount", "UA-37670561-1"] +_gaq.push ["_setDomainName", "gov.br"] +_gaq.push ["_trackPageview"] +(-> + ga = document.createElement("script") + ga.type = "text/javascript" + ga.async = true + ga.src = ((if "https:" is document.location.protocol then "https://ssl" else "http://www")) + ".google-analytics.com/ga.js" + s = document.getElementsByTagName("script")[0] + s.parentNode.insertBefore ga, s +)() diff --git a/assets/imagens/ai.png b/assets/imagens/ai.png new file mode 100644 index 0000000..3dc7b77 Binary files /dev/null and b/assets/imagens/ai.png differ diff --git a/assets/imagens/barra-brasil-v3-bgx.gif b/assets/imagens/barra-brasil-v3-bgx.gif new file mode 100644 index 0000000..4660c71 Binary files /dev/null and b/assets/imagens/barra-brasil-v3-bgx.gif differ diff --git a/assets/imagens/barra-brasil-v3-bgx.png b/assets/imagens/barra-brasil-v3-bgx.png new file mode 100644 index 0000000..5514710 Binary files /dev/null and b/assets/imagens/barra-brasil-v3-bgx.png differ diff --git a/assets/imagens/brasil.png b/assets/imagens/brasil.png new file mode 100644 index 0000000..4bc21de Binary files /dev/null and b/assets/imagens/brasil.png differ diff --git a/barra-brasil-1.yaml b/barra-brasil-1.yaml new file mode 100644 index 0000000..0640da3 --- /dev/null +++ b/barra-brasil-1.yaml @@ -0,0 +1,42 @@ +# configuracao do assetgen para: +# - gerar o script de comportamento, minificado +# - gerar o css com as imagens incorporadas + +generate: + +- barra-brasil.js: + source: + - assets/conteudo-barra.html + - assets/barra-brasil.coffee + - assets/google-analytics.coffee + - raw: "})();" # fechamento do escopo da funcao anonima (ver template abaixo) + template: | + (function(){ + var conteudoBarra = '${source|trim}'; + +- estilo-barra.css: + source: + - assets/estilo-barra.scss + depends: + - assets/imagens/* + embed.path.root: assets + embed.url.base: imagens/ + +- barra-brasil-css.js: + source: + - build/estilo-barra.css + template: | + window._barrabrasil.insere_css('${source|trim}'); + +css.embed: true +css.embed.only: true +css.compress: true +js.compress: false +js.uglify.bin: uglifyjs +output.directory: build +output.hashed: false +output.manifest: app/assets.json + +profile.dev: + css.compress: false + js.compress: false diff --git a/barra-brasil-2.yaml b/barra-brasil-2.yaml new file mode 100644 index 0000000..7f3094e --- /dev/null +++ b/barra-brasil-2.yaml @@ -0,0 +1,20 @@ +# configuracao do assetgen para: +# - mesclar o css com javascript de comportamento + +generate: + +- barra-brasil.js: + source: + - build/barra-brasil.js # parte de comportamento + - build/barra-brasil-css.js # codigo de insercao do css + uglify.bin: uglifyjs + +css.embed: true +css.embed.only: true +output.directory: app/templates +output.hashed: false +output.manifest: assets.json + +profile.dev: + css.compress: false + js.compress: false diff --git a/doc/fluxo-de-compilacao.png b/doc/fluxo-de-compilacao.png new file mode 100644 index 0000000..2b84cbb Binary files /dev/null and b/doc/fluxo-de-compilacao.png differ diff --git a/test/Teste de stress.jmx b/test/Teste de stress.jmx new file mode 100644 index 0000000..cc66ef1 --- /dev/null +++ b/test/Teste de stress.jmx @@ -0,0 +1,148 @@ + + + + + Teste de stress genérico + false + false + + + + + + + + + false + 100 + + 1000 + 0 + 1356091419000 + 1356091419000 + false + continue + + + + + + + + + barra.brasil.gov.br + + + + + + + GET + true + false + true + false + false + + + + + false + + saveConfig + + + true + true + true + + true + true + true + true + false + true + true + false + false + true + false + false + false + false + false + 0 + true + + + + + + + false + + saveConfig + + + true + true + true + + true + true + true + true + false + true + true + false + false + true + false + false + false + false + false + 0 + true + + + + + + + false + + saveConfig + + + true + true + true + + true + true + true + true + false + true + true + false + false + true + false + false + false + false + false + 0 + true + + + + + + + + + -- libgit2 0.21.2