[kune-commits] r1540 - in trunk: . img/icons src/main/java/cc/kune/core/client/sitebar/spaces src/main/java/cc/kune/core/client/sub src/main/java/cc/kune/core/public src/test/java/cc/kune/selenium src/test/java/cc/kune/selenium/chat src/test/java/cc/kune/selenium/general src/test/java/cc/kune/selenium/login src/test/java/cc/kune/selenium/tools
Vicente J. Ruiz Jurado
vjrj_ at ourproject.org
Wed Sep 28 16:04:58 CEST 2011
Author: vjrj_
Date: 2011-09-28 16:04:57 +0200 (Wed, 28 Sep 2011)
New Revision: 1540
Added:
trunk/img/icons/Black_Cursor.svg
trunk/img/icons/cursor-red.png
trunk/src/test/java/cc/kune/selenium/general/
trunk/src/test/java/cc/kune/selenium/general/EntityHeaderPageObject.java
trunk/src/test/java/cc/kune/selenium/general/SpacesPageObject.java
Removed:
trunk/src/test/java/cc/kune/selenium/login/EntityHeaderPageObject.java
Modified:
trunk/COPYRIGHT
trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPanel.java
trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPresenter.java
trunk/src/main/java/cc/kune/core/client/sub/SubtitlesWidget.java
trunk/src/main/java/cc/kune/core/public/ws.css
trunk/src/test/java/cc/kune/selenium/CustomWebDriverEventListener.java
trunk/src/test/java/cc/kune/selenium/KuneSeleniumDefaults.java
trunk/src/test/java/cc/kune/selenium/PageObject.java
trunk/src/test/java/cc/kune/selenium/SeleniumModule.java
trunk/src/test/java/cc/kune/selenium/SeleniumUtils.java
trunk/src/test/java/cc/kune/selenium/chat/ChatPageObject.java
trunk/src/test/java/cc/kune/selenium/chat/ChatSeleniumTests.java
trunk/src/test/java/cc/kune/selenium/login/LoginPageObject.java
trunk/src/test/java/cc/kune/selenium/login/LoginSeleniumTests.java
trunk/src/test/java/cc/kune/selenium/login/RegisterSeleniumTests.java
trunk/src/test/java/cc/kune/selenium/tools/SeleniumConstants.java
Log:
CLOSED - # 53: Add Selenium Framework testing
http://kune.ourproject.org/issues/ticket/53
Modified: trunk/COPYRIGHT
===================================================================
--- trunk/COPYRIGHT 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/COPYRIGHT 2011-09-28 14:04:57 UTC (rev 1540)
@@ -185,4 +185,8 @@
Creative Commons Attribution 3.0 Unported license
https://secure.wikimedia.org/wikipedia/commons/wiki/File:Acer_japonicum_Vitifolium_JPG1fu.jpg
-
+#Cursor#
+https://secure.wikimedia.org/wikipedia/commons/wiki/File:Black_Cursor.svg
+Ort43v
+Creative Commons Attribution-Share Alike 3.0 Unported license
+http://creativecommons.org/licenses/by-sa/3.0/deed.en
Added: trunk/img/icons/Black_Cursor.svg
===================================================================
--- trunk/img/icons/Black_Cursor.svg (rev 0)
+++ trunk/img/icons/Black_Cursor.svg 2011-09-28 14:04:57 UTC (rev 1540)
@@ -0,0 +1,271 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ version="1.1"
+ width="20"
+ height="20"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="Black_Cursor.svg">
+ <sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1078"
+ inkscape:window-height="897"
+ id="namedview35"
+ showgrid="false"
+ inkscape:showpageshadow="false"
+ showborder="false"
+ inkscape:zoom="1"
+ inkscape:cx="6.5104813"
+ inkscape:cy="10.563713"
+ inkscape:window-x="0"
+ inkscape:window-y="947"
+ inkscape:window-maximized="0"
+ inkscape:current-layer="svg2" />
+ <defs
+ id="defs4">
+ <clipPath
+ id="clipPath3058">
+ <path
+ d="m 17,550 181,0 0,266 -181,0 0,-266 z"
+ id="path3060" />
+ </clipPath>
+ <clipPath
+ id="clipPath3054">
+ <path
+ d="m 17,550 181,0 0,266 -181,0 0,-266 z"
+ id="path3056" />
+ </clipPath>
+ <clipPath
+ id="clipPath3048">
+ <path
+ d="m 0.1400146,0 594.8599954,0 0,841 -594.8599954,0 0,-841 z"
+ id="path3050" />
+ </clipPath>
+ <mask
+ id="mask3036">
+ <image
+ xlink:href=""
+ width="1"
+ height="1"
+ id="image3038" />
+ </mask>
+ <clipPath
+ id="clipPath3020">
+ <path
+ d="m 0.1400146,0 594.8599954,0 0,841 -594.8599954,0 0,-841 z"
+ id="path3022" />
+ </clipPath>
+ <mask
+ id="mask3036-4">
+ <image
+ xlink:href=""
+ width="1"
+ height="1"
+ id="image3038-4" />
+ </mask>
+ <clipPath
+ id="clipPath3048-6">
+ <path
+ inkscape:connector-curvature="0"
+ d="m 0.1400146,0 594.8599954,0 0,841 -594.8599954,0 0,-841 z"
+ id="path3050-0" />
+ </clipPath>
+ <clipPath
+ id="clipPath3054-7">
+ <path
+ inkscape:connector-curvature="0"
+ d="m 17,550 181,0 0,266 -181,0 0,-266 z"
+ id="path3056-4" />
+ </clipPath>
+ <clipPath
+ id="clipPath3058-3">
+ <path
+ inkscape:connector-curvature="0"
+ d="m 17,550 181,0 0,266 -181,0 0,-266 z"
+ id="path3060-7" />
+ </clipPath>
+ </defs>
+ <metadata
+ id="metadata7">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title />
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ transform="translate(0,-1032.3622)"
+ id="layer1"
+ inkscape:export-filename="/home/vjrj/proyectos/dev/kune/trunk/img/icons/cursor-red.png"
+ inkscape:export-xdpi="90"
+ inkscape:export-ydpi="90">
+ <g
+ transform="matrix(0.05527655,0,0,0.05527655,-22.484133,1026.5598)"
+ id="g3147">
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3014" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3028" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3030" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3032">
+ <g
+ transform="matrix(221,0,0,306,1,526)"
+ id="g3034">
+ <image
+ xlink:href=""
+ width="1"
+ height="1"
+ transform="matrix(1,0,0,-1,0,1)"
+ mask="url(#mask3036)"
+ id="image3040" />
+ </g>
+ </g>
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3042" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ clip-path="url(#clipPath3048)"
+ id="g3046">
+ <g
+ id="g3052" />
+ <g
+ id="g3062">
+ <g
+ clip-path="url(#clipPath3054)"
+ id="g3064">
+ <g
+ id="g3066" />
+ <g
+ id="g3068">
+ <g
+ clip-path="url(#clipPath3058)"
+ id="g3070">
+ <path
+ d="m 41.14001,791.145 0,-187.8 42.2,40.8 40.99999,-69.2 22.8,0 0.4,19 -36.2,68 c 0,0 16.8,0 26.4,0 11.2667,0 36.2,0 36.2,0 l -132.79999,129.2 z"
+ id="path3072"
+ style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none" />
+ <g
+ transform="matrix(1,0,0,-1,0.1400146,841.945)"
+ id="g3074">
+ <path
+ d="M 41,50.79999 41,238.6 l 42.2,-40.8 41,69.2 22.8,0 0.4,-19 -36.2,-68 c 0,0 16.8,0 26.4,0 11.2667,0 36.2,0 36.2,0 L 41,50.79999 z"
+ id="path3076"
+ style="fill:none;stroke:#ffffff;stroke-width:12;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3078" />
+ </g>
+ </g>
+ <g
+ transform="matrix(0.72543777,1.3129128,-1.3129128,0.72543777,1407.0677,-758.30765)"
+ id="layer1-9"
+ inkscape:export-filename="/home/vjrj/proyectos/dev/kune/trunk/img/icons/cursor-red.png"
+ inkscape:export-xdpi="90"
+ inkscape:export-ydpi="90">
+ <g
+ transform="matrix(0.05527655,0,0,0.05527655,-22.484133,1026.5598)"
+ id="g3147-0">
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3014-0" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3028-2" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3030-2" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3032-6">
+ <g
+ transform="matrix(221,0,0,306,1,526)"
+ id="g3034-9">
+ <image
+ xlink:href=""
+ width="1"
+ height="1"
+ transform="matrix(1,0,0,-1,0,1)"
+ mask="url(#mask3036-4)"
+ id="image3040-0" />
+ </g>
+ </g>
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3042-3" />
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ clip-path="url(#clipPath3048-6)"
+ id="g3046-5">
+ <g
+ id="g3052-5" />
+ <g
+ id="g3062-8">
+ <g
+ clip-path="url(#clipPath3054-7)"
+ id="g3064-7">
+ <g
+ id="g3066-1" />
+ <g
+ id="g3068-7">
+ <g
+ clip-path="url(#clipPath3058-3)"
+ id="g3070-0">
+ <path
+ d="m 41.14001,791.145 0,-187.8 42.2,40.8 40.99999,-69.2 22.8,0 0.4,19 -36.2,68 c 0,0 16.8,0 26.4,0 11.2667,0 36.2,0 36.2,0 l -132.79999,129.2 z"
+ id="path3072-6"
+ style="fill:#d40000;fill-opacity:1;fill-rule:nonzero;stroke:none"
+ inkscape:connector-curvature="0" />
+ <g
+ transform="matrix(1,0,0,-1,0.1400146,841.945)"
+ id="g3074-0">
+ <path
+ d="M 41,50.79999 41,238.6 l 42.2,-40.8 41,69.2 22.8,0 0.4,-19 -36.2,-68 c 0,0 16.8,0 26.4,0 11.2667,0 36.2,0 36.2,0 L 41,50.79999 z"
+ id="path3076-4"
+ style="fill:none;stroke:#ffffff;stroke-width:12;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+ inkscape:connector-curvature="0" />
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ <g
+ transform="matrix(1.25,0,0,-1.25,385.16156,1124.4318)"
+ id="g3078-1" />
+ </g>
+ </g>
+</svg>
Added: trunk/img/icons/cursor-red.png
===================================================================
(Binary files differ)
Property changes on: trunk/img/icons/cursor-red.png
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Modified: trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPanel.java
===================================================================
--- trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPanel.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPanel.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -72,6 +72,11 @@
userSpaceTooltip.setWidth(190);
groupSpaceTooltip.setWidth(170);
publicSpaceTooltip.setWidth(150);
+
+ homeButton.ensureDebugId(HOME_SPACE_ID);
+ userButton.ensureDebugId(USER_SPACE_ID);
+ groupButton.ensureDebugId(GROUP_SPACE_ID);
+ publicButton.ensureDebugId(PUBLIC_SPACE_ID);
}
@Override
Modified: trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPresenter.java
===================================================================
--- trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPresenter.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/main/java/cc/kune/core/client/sitebar/spaces/SpaceSelectorPresenter.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -56,6 +56,11 @@
public interface SpaceSelectorView extends View {
+ public static String GROUP_SPACE_ID = "k-space-group-id";
+ public static String HOME_SPACE_ID = "k-space-home-id";
+ public static String PUBLIC_SPACE_ID = "k-space-public-id";
+ public static String USER_SPACE_ID = "k-space-user-id";
+
HasClickHandlers getGroupBtn();
HasClickHandlers getHomeBtn();
Modified: trunk/src/main/java/cc/kune/core/client/sub/SubtitlesWidget.java
===================================================================
--- trunk/src/main/java/cc/kune/core/client/sub/SubtitlesWidget.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/main/java/cc/kune/core/client/sub/SubtitlesWidget.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -49,7 +49,7 @@
@Override
public void onClick(final ClickEvent event) {
if (showing) {
- final SlideRight slideAtEnd = new SlideRight(popup.getElement());
+ final SlideRight slideAtEnd = new SlideRight(widget.getElement());
slideAtEnd.invert();
slideAtEnd.setDuration(2);
slideAtEnd.play();
@@ -101,11 +101,11 @@
setSize(Window.getClientWidth(), Window.getClientHeight());
popup.sinkEvents(Event.MOUSEEVENTS);
popup.show();
- final Show showAtIni = new Show(popup.getElement());
- showAtIni.setDuration(3);
+ final Show showAtIni = new Show(widget.getElement());
+ showAtIni.setDuration(2);
showAtIni.play();
- final SlideRight slideAtIni = new SlideRight(popup.getElement());
- slideAtIni.setDuration(3);
+ final SlideRight slideAtIni = new SlideRight(widget.getElement());
+ slideAtIni.setDuration(2);
slideAtIni.play();
this.showing = true;
}
Modified: trunk/src/main/java/cc/kune/core/public/ws.css
===================================================================
--- trunk/src/main/java/cc/kune/core/public/ws.css 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/main/java/cc/kune/core/public/ws.css 2011-09-28 14:04:57 UTC (rev 1540)
@@ -1,4 +1,4 @@
-CHARSET "UTF-8 "; body {
+GCHARSET "UTF-8 "; body {
background-color: transparent;
color: black;
font-family: 'Ubuntu', Arial;
@@ -944,7 +944,7 @@
border-color: #CCCCCC !important;
background: inherits !important;
kfilter: alpha(opacity =
- 60) !important;
+ 60) !important;
-moz-opacity: 0.60 !important;
-khtml-opacity: 0.60 !important;
opacity: 0.60 !important;
@@ -1230,7 +1230,7 @@
-moz-border-radius-bottomleft: 5px;
border-bottom-left-radius: 5px;
kfilter: alpha(opacity =
- 90);
+ 90);
-moz-opacity: 0.90;
-khtml-opacity: 0.90;
opacity: 0.90;
@@ -1527,3 +1527,8 @@
outline: #f90 solid 2px !important;
outline-offset: -2px !important;
}
+
+div.jGrowl div.jGrowl-notification div.header {
+ background-color: #000000 !important;
+ padding: 0 !important;
+}
\ No newline at end of file
Modified: trunk/src/test/java/cc/kune/selenium/CustomWebDriverEventListener.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/CustomWebDriverEventListener.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/CustomWebDriverEventListener.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -44,6 +44,7 @@
@Override
public void beforeChangeValueOf(final WebElement element, final WebDriver driver) {
+ SeleniumUtils.hightlight(element, driver);
}
@Override
Modified: trunk/src/test/java/cc/kune/selenium/KuneSeleniumDefaults.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/KuneSeleniumDefaults.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/KuneSeleniumDefaults.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -24,6 +24,7 @@
import org.openqa.selenium.By;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
+import org.openqa.selenium.WebElement;
import org.openqa.selenium.support.PageFactory;
import org.openqa.selenium.support.pagefactory.ElementLocatorFactory;
import org.testng.ITestContext;
@@ -36,7 +37,8 @@
import cc.kune.core.client.sub.SubtitlesWidget;
import cc.kune.core.shared.domain.utils.StateToken;
import cc.kune.selenium.chat.ChatPageObject;
-import cc.kune.selenium.login.EntityHeaderPageObject;
+import cc.kune.selenium.general.EntityHeaderPageObject;
+import cc.kune.selenium.general.SpacesPageObject;
import cc.kune.selenium.login.LoginPageObject;
import cc.kune.selenium.login.RegisterPageObject;
import cc.kune.selenium.tools.SeleniumConstants;
@@ -56,6 +58,7 @@
private final Injector injector;
protected LoginPageObject login;
protected RegisterPageObject register;
+ protected final SpacesPageObject spaces;
private final WebDriver webdriver;
public KuneSeleniumDefaults() {
@@ -66,11 +69,13 @@
login = injector.getInstance(LoginPageObject.class);
register = injector.getInstance(RegisterPageObject.class);
entityHeader = injector.getInstance(EntityHeaderPageObject.class);
+ spaces = injector.getInstance(SpacesPageObject.class);
chat = injector.getInstance(ChatPageObject.class);
final ElementLocatorFactory locator = injector.getInstance(ElementLocatorFactory.class);
PageFactory.initElements(locator, login);
PageFactory.initElements(locator, register);
PageFactory.initElements(locator, entityHeader);
+ PageFactory.initElements(locator, spaces);
PageFactory.initElements(locator, chat);
}
@@ -145,24 +150,39 @@
public void resize() {
final JavascriptExecutor js = (JavascriptExecutor) webdriver;
+ // Some others tested values:
// 1024,769
- js.executeScript("window.resizeTo(840,770); window.moveTo(0,0);");
+ // 840,770
+ // 806,707
+ js.executeScript("window.resizeTo(806,707); window.moveTo(0,0);");
}
- public void showSubtitle(final String title) {
- showSubtitle(title, "", "");
+ public void showMsg(final String msg) {
+ SeleniumUtils.showMsg(webdriver, "", msg);
}
- public void showSubtitle(final String title, final String description) {
- showSubtitle(title, description, "");
+ public void showMsg(final String title, final String msg) {
+ SeleniumUtils.showMsg(webdriver, title, msg);
}
- public void showSubtitle(final String title, final String description, final String token) {
+ public void showTitleSlide(final String title) {
+ showTitleSlide(title, "", "");
+ }
+
+ public void showTitleSlide(final String title, final String description) {
+ showTitleSlide(title, description, "");
+ }
+
+ public void showTitleSlide(final String title, final String description, final String token) {
gotoToken(TokenUtils.subtitle(title, description, token));
sleep(3000);
webdriver.findElement(By.id(SeleniumConstants.GWTDEV + SubtitlesWidget.SUBTITLE_MANAGER_ID)).click();
}
+ public void showTooltip(final WebElement element) {
+ SeleniumUtils.showTooltip(webdriver, element);
+ }
+
public void sleep(final int milliseconds) {
SeleniumUtils.sleep(milliseconds);
}
Modified: trunk/src/test/java/cc/kune/selenium/PageObject.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/PageObject.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/PageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -32,7 +32,6 @@
import org.openqa.selenium.WebDriver.Options;
import org.openqa.selenium.WebDriver.TargetLocator;
import org.openqa.selenium.WebElement;
-import org.openqa.selenium.interactions.Actions;
import org.openqa.selenium.support.ByIdOrName;
import org.openqa.selenium.support.ui.ExpectedCondition;
import org.openqa.selenium.support.ui.Wait;
@@ -120,12 +119,6 @@
return webdriver.manage();
}
- public void moveMouseTo(final WebElement element) {
- final Actions actions = new Actions(webdriver);
- actions.moveToElement(element);
- sleep(1000);
- }
-
public Navigation navigate() {
return webdriver.navigate();
}
@@ -134,6 +127,10 @@
webdriver.quit();
}
+ public void showTooltip(final WebElement element) {
+ SeleniumUtils.showTooltip(webdriver, element);
+ }
+
public void sleep(final int milliseconds) {
SeleniumUtils.sleep(milliseconds);
}
Modified: trunk/src/test/java/cc/kune/selenium/SeleniumModule.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/SeleniumModule.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/SeleniumModule.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -33,7 +33,8 @@
import org.openqa.selenium.support.pagefactory.ElementLocatorFactory;
import cc.kune.selenium.chat.ChatPageObject;
-import cc.kune.selenium.login.EntityHeaderPageObject;
+import cc.kune.selenium.general.EntityHeaderPageObject;
+import cc.kune.selenium.general.SpacesPageObject;
import cc.kune.selenium.login.LoginPageObject;
import cc.kune.selenium.login.RegisterPageObject;
import cc.kune.selenium.tools.SeleniumConstants;
@@ -59,6 +60,7 @@
bind(RegisterPageObject.class).in(Singleton.class);
bind(EntityHeaderPageObject.class).in(Singleton.class);
bind(ChatPageObject.class).in(Singleton.class);
+ bind(SpacesPageObject.class).in(Singleton.class);
}
@SuppressWarnings("unused")
Modified: trunk/src/test/java/cc/kune/selenium/SeleniumUtils.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/SeleniumUtils.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/SeleniumUtils.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -3,19 +3,42 @@
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
+import org.openqa.selenium.interactions.Actions;
import org.testng.Assert;
+import cc.kune.common.client.utils.TextUtils;
+
public class SeleniumUtils {
public static void hightlight(final WebElement element, final WebDriver webdriver) {
final JavascriptExecutor js = (JavascriptExecutor) webdriver;
final String script = "window.jQuery('#" + element.getAttribute("id") + "').addClass('k-outline');"
+ "setTimeout('window.jQuery(\"#" + element.getAttribute("id")
- + "\").removeClass(\"k-outline\")', 700);";
+ + "\").removeClass(\"k-outline\")', 1200);";
+ // Antes 700
// LOG.info("High: " + script);
js.executeScript(script);
}
+ public static void moveMouseTo(final WebDriver webdriver, final WebElement element) {
+ final Actions actions = new Actions(webdriver);
+ actions.moveToElement(element);
+ }
+
+ public static void showMsg(final WebDriver webdriver, final String header, final String msg) {
+ final JavascriptExecutor js = (JavascriptExecutor) webdriver;
+ final String opts = TextUtils.notEmpty(header) ? "header: '" + header + "'," : "";
+ // sticky: true,
+ final String script = "window.jQuery.jGrowl(\"" + msg + "\", { " + opts + " theme: 'k-jgrowl' } )";
+ js.executeScript(script);
+ }
+
+ public static void showTooltip(final WebDriver webdriver, final WebElement element) {
+ SeleniumUtils.moveMouseTo(webdriver, element);
+ SeleniumUtils.hightlight(element, webdriver);
+ sleep(2000);
+ }
+
public static void sleep(final int milliseconds) {
try {
Thread.sleep(milliseconds);
Modified: trunk/src/test/java/cc/kune/selenium/chat/ChatPageObject.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/chat/ChatPageObject.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/chat/ChatPageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -75,6 +75,10 @@
return findElement(new ByIdOrName(id));
}
+ public WebElement icon() {
+ return chatIcon;
+ }
+
public void openChat(final XmppURI uri) {
openChat.click();
jid.sendKeys(uri.toString());
Modified: trunk/src/test/java/cc/kune/selenium/chat/ChatSeleniumTests.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/chat/ChatSeleniumTests.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/chat/ChatSeleniumTests.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -31,10 +31,11 @@
public void basicChat() {
// 15 chars, the limit, so we don't use shortName
login();
- showSubtitle("Chat with your buddies", "compatible with gmail and similars");
+ showTitleSlide("Chat with your buddies", "compatible with gmail and similars");
chat.show();
final XmppURI jid = XmppURI.jid(ChatPageObject.DEF_TESTING_USER);
final String jids = jid.toString();
+ showMsg("We need to add buddies (contacts) before chat with them");
chat.openChat(jid);
// chat.getPage(jids).click();
chat.getTalkBox(jids).sendKeys("Helloo... ;)");
Copied: trunk/src/test/java/cc/kune/selenium/general/EntityHeaderPageObject.java (from rev 1538, trunk/src/test/java/cc/kune/selenium/login/EntityHeaderPageObject.java)
===================================================================
--- trunk/src/test/java/cc/kune/selenium/general/EntityHeaderPageObject.java (rev 0)
+++ trunk/src/test/java/cc/kune/selenium/general/EntityHeaderPageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -0,0 +1,42 @@
+/*
+ *
+ * Copyright (C) 2007-2011 The kune development team (see CREDITS for details)
+ * This file is part of kune.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+package cc.kune.selenium.general;
+
+import org.openqa.selenium.WebElement;
+import org.openqa.selenium.support.FindBy;
+
+import cc.kune.core.client.ws.entheader.EntityTextLogo;
+import cc.kune.selenium.PageObject;
+import cc.kune.selenium.tools.SeleniumConstants;
+
+public class EntityHeaderPageObject extends PageObject {
+
+ @FindBy(id = SeleniumConstants.GWTDEV + EntityTextLogo.LOGO_IMAGE)
+ protected WebElement logoImage;
+ @FindBy(id = SeleniumConstants.GWTDEV + EntityTextLogo.LOGO_NAME)
+ protected WebElement logoName;
+
+ public EntityHeaderPageObject() {
+ }
+
+ public void waitForEntityTitle(final String text) {
+ waitFor(logoName, text);
+ }
+}
Added: trunk/src/test/java/cc/kune/selenium/general/SpacesPageObject.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/general/SpacesPageObject.java (rev 0)
+++ trunk/src/test/java/cc/kune/selenium/general/SpacesPageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -0,0 +1,59 @@
+/*
+ *
+ * Copyright (C) 2007-2011 The kune development team (see CREDITS for details)
+ * This file is part of kune.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+package cc.kune.selenium.general;
+
+import org.openqa.selenium.WebElement;
+import org.openqa.selenium.support.FindBy;
+
+import cc.kune.core.client.sitebar.spaces.SpaceSelectorPresenter.SpaceSelectorView;
+import cc.kune.selenium.PageObject;
+import cc.kune.selenium.tools.SeleniumConstants;
+
+public class SpacesPageObject extends PageObject {
+
+ @FindBy(id = SeleniumConstants.GWTDEV + SpaceSelectorView.GROUP_SPACE_ID)
+ protected WebElement groupSpaceBtn;
+ @FindBy(id = SeleniumConstants.GWTDEV + SpaceSelectorView.HOME_SPACE_ID)
+ protected WebElement homeSpaceBtn;
+ @FindBy(id = SeleniumConstants.GWTDEV + SpaceSelectorView.PUBLIC_SPACE_ID)
+ protected WebElement publicSpaceBtn;
+ @FindBy(id = SeleniumConstants.GWTDEV + SpaceSelectorView.USER_SPACE_ID)
+ protected WebElement userSpaceBtn;
+
+ public SpacesPageObject() {
+ }
+
+ public WebElement groupBtn() {
+ return groupSpaceBtn;
+ }
+
+ public WebElement homeBtn() {
+ return homeSpaceBtn;
+ }
+
+ public WebElement publicBtn() {
+ return publicSpaceBtn;
+ }
+
+ public WebElement userBtn() {
+ return userSpaceBtn;
+ }
+
+}
Deleted: trunk/src/test/java/cc/kune/selenium/login/EntityHeaderPageObject.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/login/EntityHeaderPageObject.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/login/EntityHeaderPageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -1,42 +0,0 @@
-/*
- *
- * Copyright (C) 2007-2011 The kune development team (see CREDITS for details)
- * This file is part of kune.
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
-package cc.kune.selenium.login;
-
-import org.openqa.selenium.WebElement;
-import org.openqa.selenium.support.FindBy;
-
-import cc.kune.core.client.ws.entheader.EntityTextLogo;
-import cc.kune.selenium.PageObject;
-import cc.kune.selenium.tools.SeleniumConstants;
-
-public class EntityHeaderPageObject extends PageObject {
-
- @FindBy(id = SeleniumConstants.GWTDEV + EntityTextLogo.LOGO_IMAGE)
- protected WebElement logoImage;
- @FindBy(id = SeleniumConstants.GWTDEV + EntityTextLogo.LOGO_NAME)
- protected WebElement logoName;
-
- public EntityHeaderPageObject() {
- }
-
- public void waitForEntityTitle(final String text) {
- waitFor(logoName, text);
- }
-}
Modified: trunk/src/test/java/cc/kune/selenium/login/LoginPageObject.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/login/LoginPageObject.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/login/LoginPageObject.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -90,8 +90,7 @@
public void signIn(final String username, final String password, final boolean withReturn) {
assertIsDisconnected();
- // hightlight(signInLink);
- moveMouseTo(signInLink);
+ showTooltip(signInLink);
signInLink.click();
fillSigInInForm(username, password, withReturn);
}
Modified: trunk/src/test/java/cc/kune/selenium/login/LoginSeleniumTests.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/login/LoginSeleniumTests.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/login/LoginSeleniumTests.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -47,7 +47,7 @@
@Test(dataProvider = "correctlogin")
public void basicSignIn(final String user, final String passwd) {
login.assertIsDisconnected();
- showSubtitle("User sign in", "to get full access to this site");
+ showTitleSlide("User sign in", "to get full access to this site");
login.signIn(user, passwd);
login.assertIsConnectedAs(user);
login.logout();
Modified: trunk/src/test/java/cc/kune/selenium/login/RegisterSeleniumTests.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/login/RegisterSeleniumTests.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/login/RegisterSeleniumTests.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -21,8 +21,12 @@
import org.testng.annotations.Test;
+import cc.kune.core.client.state.SiteTokens;
import cc.kune.selenium.KuneSeleniumTest;
+import cc.kune.selenium.tools.SeleniumConstants;
+import com.calclab.emite.core.client.xmpp.stanzas.XmppURI;
+
public class RegisterSeleniumTests extends KuneSeleniumTest {
@Test(dataProvider = "correctregister")
@@ -30,15 +34,36 @@
final String email) {
// 15 chars, the limit, so we don't use shortName
final String prefix = getTempString();
- showSubtitle("User registration", "to get full access to this site tools/contents");
+ showTitleSlide("User registration", "to get full access to this site tools/contents");
login.createOne();
register.fillRegisterForm(prefix, prefix + longName, passwd, prefix + email, false);
login.assertIsConnectedAs(prefix);
sleep(1000);
entityHeader.waitForEntityTitle(prefix + longName);
register.getWelcomeMsg().click();
+
+ // user space
+ showTitleSlide("User space (your Inbox)", "contents in which you participate");
+ showTooltip(spaces.userBtn());
+ spaces.userBtn().click();
+
+ // chat
+ showTitleSlide("Chat with your buddies", "compatible with gmail and similars", SiteTokens.WAVEINBOX);
+ showTooltip(chat.icon());
chat.show();
sleep(3000);
+
+ final XmppURI jid = XmppURI.jid(SeleniumConstants.USER_EMAIL);
+ final String jids = jid.toString();
+ showMsg("We need to add buddies (contacts) before chat with them");
+ chat.openChat(jid);
+
+ // chat.getPage(jids).click();
+ chat.getTalkBox(jids).sendKeys("Helloo... ;)");
+ chat.getSend(jids).click();
+ chat.getTalkBox(jids).sendKeys("I'm just testing");
+ chat.getSend(jids).click();
+
login.logout();
}
Modified: trunk/src/test/java/cc/kune/selenium/tools/SeleniumConstants.java
===================================================================
--- trunk/src/test/java/cc/kune/selenium/tools/SeleniumConstants.java 2011-09-27 21:01:37 UTC (rev 1539)
+++ trunk/src/test/java/cc/kune/selenium/tools/SeleniumConstants.java 2011-09-28 14:04:57 UTC (rev 1540)
@@ -23,7 +23,7 @@
public static final String FIREFOX_PROFILE_NAME = "selenium";
public static final String GWTDEV = "gwt-debug-";
public static final String INPUT = "-input";
- public static final int TIMEOUT = 15;
+ public static final int TIMEOUT = 20;
public static final String USER_EMAIL = "admin at example.org";
public static final String USER_LONGNAME = "Administrator";
public static final String USER_PASSWD = "easyeasy";
More information about the kune-commits
mailing list