forked from pythonclub/pythonclub.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathselenium-parte-3.html
More file actions
263 lines (231 loc) · 16 KB
/
selenium-parte-3.html
File metadata and controls
263 lines (231 loc) · 16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="PythonClub, ">
<link rel="alternate" href="http://pythonclub.com.br/feeds/all.atom.xml" type="application/atom+xml" title="PythonClub Full Atom Feed"/>
<link rel="shortcut icon" href="http://pythonclub.com.br/theme/images/favicon.ico" >
<title>Selenium - O que você deveria saber - Parte 3 por Lucas Magnum // #PythonClub // </title>
<meta property="fb:app_id" content="1487080281503641" />
<meta property="og:type" content="article" />
<meta property="og:title" content="Selenium - O que você deveria saber - Parte 3" />
<meta property="og:site_name" content="PythonClub" />
<meta property="og:url" content="http://pythonclub.com.br/selenium-parte-3.html" />
<meta property="og:description" content="Esse é o terceiro post da série sobre Selenium, hoje vamos aprender a executar código javascript e usar diferentes navegadores. Veja a primeira parte. Veja a segunda parte. Parte 3 Executando código javascript Como utilizar diferentes navegadores Executando código javascript Algumas vezes é necessário executar algum código javascript, seja para ..." />
<meta property="og:image" content="http://res.cloudinary.com/diu8g9l0s/image/upload/v1400201393/pythonclub/logo_275x130.png" />
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/pure/0.3.0/pure-min.css">
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/font-awesome/4.0.3/css/font-awesome.min.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/pure.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/custom.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/pygments.css">
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-50935105-1', 'pythonclub.com.br');
ga('require', 'linkid', 'linkid.js');
ga('send', 'pageview');
</script>
</head>
<body>
<div class="pure-g-r" id="layout">
<div class="sidebar sidebar-article pure-u">
<header class="header-article">
<hgroup>
<a href="http://pythonclub.com.br/author/lucas-magnum.html" title="See posts by Lucas Magnum">
<img class="article-avatar" alt="Lucas Magnum" src="http://www.gravatar.com/avatar/f880a9c9877b6103cefae911ffeabf43">
</a>
<h2 class="article-info">Lucas Magnum</h2>
<ul class="author-social">
<li>
<a target="_blank" href="https://github.com/lucasmagnum">
<i class="fa fa-lg fa-fw fa-github"></i>
<strong>Github</strong>
</a>
</li>
<li>
<a target="_blank" href="http://www.linkedin.com/in/lucasmagnum">
<i class="fa fa-lg fa-fw fa-linkedin"></i>
<strong>Linkedin</strong>
</a>
</li>
</ul>
<h5>Publicado em:</h5>
<p>Mon 02 June 2014</p>
<a href="/">←Home</a>
</hgroup>
</header>
</div>
<div class="pure-u">
<div class="content">
<section class="post">
<header class="post-header">
<h1>Selenium - O que você deveria saber - Parte 3</h1>
<p class="post-meta">
// Tags <a class="post-category" href="http://pythonclub.com.br/tag/selenium.html">selenium</a>
<a class="post-category" href="http://pythonclub.com.br/tag/python.html">python</a>
<a class="post-category" href="http://pythonclub.com.br/tag/selenium-serie.html">selenium-serie</a>
</p>
</header>
</section>
<p>Esse é o terceiro post da série sobre Selenium, hoje vamos aprender a executar código javascript e usar diferentes navegadores.</p>
<blockquote>
<ul class="simple">
<li>Veja a <a class="reference external" href="http://pythonclub.com.br/selenium-parte-1.html">primeira parte</a>.</li>
<li>Veja a <a class="reference external" href="http://pythonclub.com.br/selenium-parte-2.html">segunda parte</a>.</li>
</ul>
</blockquote>
<div class="section" id="parte-3">
<h2>Parte 3</h2>
<blockquote>
<ul class="simple">
<li><a class="reference internal" href="#executando-codigo-javascript">Executando código javascript</a></li>
<li><a class="reference internal" href="#como-utilizar-diferentes-navegadores">Como utilizar diferentes navegadores</a></li>
</ul>
</blockquote>
<div class="section" id="executando-codigo-javascript">
<h3>Executando código javascript</h3>
<p>Algumas vezes é necessário executar algum código <tt class="docutils literal">javascript</tt>, seja para adiantar a execução de uma função
ou até mesmo para manipular um elemento.</p>
<p>Vamos ao nosso exemplo:</p>
<div class="highlight"><pre><span class="kn">from</span> <span class="nn">selenium</span> <span class="kn">import</span> <span class="n">webdriver</span>
<span class="n">firefox</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Firefox</span><span class="p">()</span>
<span class="n">firefox</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s">'http://google.com.br/'</span><span class="p">)</span>
<span class="n">firefox</span><span class="o">.</span><span class="n">execute_script</span><span class="p">(</span><span class="s">'alert("código javascript sendo executado")'</span><span class="p">)</span>
<span class="n">firefox</span><span class="o">.</span><span class="n">execute_async_script</span><span class="p">(</span><span class="s">'alert("código javascript sendo executado")'</span><span class="p">)</span>
</pre></div>
<p>O Selenium permite que você faça isso através de uma instância do navegador, chamando os metódos <tt class="docutils literal">execute_script</tt> e <tt class="docutils literal">execute_async_script</tt>.</p>
<p>A diferença entre os dois é que o primeiro (<tt class="docutils literal">execute_script</tt>) irá esperar até ter a resposta do navegador e o outro não.</p>
<p>Você pode executar qualquer código javascript e isso pode ser muito útil!</p>
</div>
<div class="section" id="como-utilizar-diferentes-navegadores">
<h3>Como utilizar diferentes navegadores</h3>
<p>Para utilizar navegadores diferentes é bem simples, vamos ver como configurar 2 navegadores diferentes.</p>
</div>
</div>
<div class="section" id="firefox">
<h2>Firefox</h2>
<p>O <em>Firefox</em> é o mais simples de ser configurado, você não precisa passar nenhum parâmetro adicional.</p>
<div class="highlight"><pre><span class="kn">from</span> <span class="nn">selenium</span> <span class="kn">import</span> <span class="n">webdriver</span>
<span class="n">firefox</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Firefox</span><span class="p">()</span>
</pre></div>
<p>Se a instalação do firefox tiver sido alterada e feito em alguma pasta diferente da padrão, você pode informar o caminho para o executável.</p>
<div class="highlight"><pre><span class="kn">from</span> <span class="nn">selenium</span> <span class="kn">import</span> <span class="n">webdriver</span>
<span class="n">firefox</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Firefox</span><span class="p">(</span><span class="n">firefox_binary</span><span class="o">=</span><span class="s">'/bin/firefox'</span><span class="p">)</span>
<span class="c"># se estiver usando o windows, basta informar o caminho completo</span>
<span class="n">firefox</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Firefox</span><span class="p">(</span><span class="n">firefox_binary</span><span class="o">=</span><span class="s">'C:/firefox/firefox.exe'</span><span class="p">)</span>
</pre></div>
</div>
<div class="section" id="chrome">
<h2>Chrome</h2>
<p>Para utilizar <em>Chrome</em> você precisa ter instalado o chrome no seu computador, você pode fazer isso pelo terminal:</p>
<div class="highlight"><pre>apt-get install chromium-browser
</pre></div>
<p>Após instalar o navegador você precisa realizar o download do <tt class="docutils literal">chromedriver</tt> que é um intermediário entre o Selenium o e Chrome.</p>
<p>Por default o Selenium procura pelo <tt class="docutils literal">chromedriver</tt> na mesma pasta de onde está sendo executado.</p>
<p>Faça o download da ultima versão do <a class="reference external" href="http://chromedriver.storage.googleapis.com/index.html">chromedriver</a>, coloque em um local de sua preferência e passe o caminho completo na hora de iniciar o navegador.</p>
<div class="highlight"><pre><span class="kn">from</span> <span class="nn">selenium</span> <span class="kn">import</span> <span class="n">webdriver</span>
<span class="n">chrome</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Chrome</span><span class="p">(</span><span class="n">executable_path</span><span class="o">=</span><span class="s">'<caminho para chromedriver>'</span><span class="p">)</span>
<span class="c"># exemplo</span>
<span class="n">chrome</span> <span class="o">=</span> <span class="n">webdriver</span><span class="o">.</span><span class="n">Chrome</span><span class="p">(</span><span class="n">executable_path</span><span class="o">=</span><span class="s">'/home/lucasmagnum/downloads/chromedriver'</span><span class="p">)</span>
</pre></div>
<p>Você pode visualizar todos os navegadores <a class="reference external" href="http://docs.seleniumhq.org/about/platforms.jsp">suportados</a> pelo Selenium</p>
<p>Por hoje é só!
Nos vemos na próxima, espero que tenha aprendido algo hoje :)</p>
</div>
<div class="licence">
<a rel="license" href="http://creativecommons.org/licenses/by-nc-nd/4.0/"><img alt="Licença Creative Commons"
style="border-width:0"
src="http://i.creativecommons.org/l/by-nc-nd/4.0/88x31.png"/></a><br/><a
xmlns:dct="http://purl.org/dc/terms/" property="dct:title"
href="http://pythonclub.com.br/selenium-parte-3.html">"Selenium - O que você deveria saber - Parte 3"</a> de <a
xmlns:cc="http://creativecommons.org/ns#" href="http://pythonclub.com.br/author/lucas-magnum.html"
property="cc:attributionName" rel="cc:attributionURL">"Lucas Magnum"</a> está licenciado com uma Licença
<a rel="license" href="http://creativecommons.org/licenses/by-nc-nd/4.0/">Creative Commons -
Atribuição-NãoComercial-SemDerivações 4.0 Internacional</a>.
</div>
<div class="sharing">
<!-- Facebook sharing -->
<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/pt_BR/sdk.js#xfbml=1&appId=1487080281503641&version=v2.0";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div class="fb-share-button" data-href="http://pythonclub.com.br/selenium-parte-3.html" data-type="button_count"></div>
<!-- Google+ sharing -->
<div class="g-plus alinhar" data-action="share" data-annotation="bubble" data-href="http://pythonclub.com.br/selenium-parte-3.html"></div>
<!-- Twitter sharing -->
<a href="https://twitter.com/share" class="twitter-share-button" data-lang="pt" style="margin-bottom: -4px !important;">Tweetar</a>
<script>!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?'http':'https';if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src=p+'://platform.twitter.com/widgets.js';fjs.parentNode.insertBefore(js,fjs);}}(document, 'script', 'twitter-wjs');</script>
</div>
<div class="hr"></div>
<a href="#" class="go-top">Topo</a>
<div class="comments">
<div id="disqus_thread"></div>
<script type="text/javascript">
/* * * CONFIGURATION VARIABLES: THIS CODE IS ONLY AN EXAMPLE * * */
var disqus_shortname = 'pythonclub'; // Required - Replace example with your forum shortname
var disqus_identifier = 'selenium-parte-3.html';
var disqus_title = 'Selenium - O que você deveria saber - Parte 3';
var disqus_url = 'http://pythonclub.com.br/selenium-parte-3.html';
/* * * DON'T EDIT BELOW THIS LINE * * */
(function() {
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
})();
</script>
<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
<a href="http://disqus.com" class="dsq-brlink">comments powered by <span class="logo-disqus">Disqus</span></a>
</div>
<footer class="footer">
<p>© PythonClub –
Built with <a href="https://github.com/PurePelicanTheme/pure">Pure Theme</a>
for <a href="http://blog.getpelican.com/">Pelican</a>
</p>
</footer> </div>
</div>
</div>
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/fitvids/1.0.1/jquery.fitvids.min.js"></script>
<script>
$(document).ready(function(){
$(".content").fitVids();
});
$(window).load(function(){
$("iframe").css("margin-bottom", "-6px")
$("#twitter-widget-0").css("margin-bottom", "-5px");
$("#twitter-widget-0").css("margin-left", "-1px");
});
</script>
<script type="text/javascript" src="https://apis.google.com/js/platform.js">
{lang: 'pt-BR'}
</script>
<script>
var $top = $('.go-top');
// Show or hide the sticky footer button
$(window).scroll(function() {
if ($(this).scrollTop() > 200) {
$top.fadeIn(200);
} else {
$top.fadeOut(200);
}
});
// Animate the scroll to top
$top.click(function(event) {
event.preventDefault();
$('html, body').animate({scrollTop: 0}, 300);
})
// Makes sure that the href="#" attached to the <a> elements
// don't scroll you back up the page.
$('body').on('click', 'a[href="#"]', function(event) {
event.preventDefault();
});
</script>
</body>
</html>