diff --git a/.buildkite/pipeline.yaml b/.buildkite/pipeline.yaml
new file mode 100644
index 0000000000..04b047436b
--- /dev/null
+++ b/.buildkite/pipeline.yaml
@@ -0,0 +1,60 @@
+steps:
+ - label: ":eslint: Lint"
+ command:
+ - "yarn install"
+ - "yarn lintwithexclusions"
+ plugins:
+ - docker#v3.0.1:
+ image: "node:10"
+
+# - label: ":chains: End-to-End Tests"
+# command:
+# # TODO: Remove hacky chmod for BuildKite
+# - "chmod +x ./scripts/ci/*.sh"
+# - "chmod +x ./scripts/*"
+# - "sudo apt-get install build-essential python2.7-dev libffi-dev python-pip python-setuptools sqlite3 libssl-dev python-virtualenv libjpeg-dev libxslt1-dev"
+# - "./scripts/ci/install-deps.sh"
+# - "./scripts/ci/end-to-end-tests.sh"
+# plugins:
+# - docker#v3.0.1:
+# image: "node:10"
+
+ - label: ":karma: Tests"
+ command:
+ # Install chrome
+ - "wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add -"
+ - "sh -c 'echo \"deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main\" >> /etc/apt/sources.list.d/google.list'"
+ - "apt-get update"
+ - "apt-get install -y google-chrome-stable"
+ # Run tests
+ # TODO: Remove hacky chmod for BuildKite
+ - "chmod +x ./scripts/ci/*.sh"
+ - "chmod +x ./scripts/*"
+ - "./scripts/ci/install-deps.sh"
+ - "./scripts/ci/unit-tests.sh"
+ env:
+ CHROME_BIN: "/usr/bin/google-chrome-stable"
+ plugins:
+ - docker#v3.0.1:
+ image: "node:10"
+ propagate-environment: true
+
+ - label: "🔧 Riot Tests"
+ command:
+ # Install chrome
+ - "wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add -"
+ - "sh -c 'echo \"deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main\" >> /etc/apt/sources.list.d/google.list'"
+ - "apt-get update"
+ - "apt-get install -y google-chrome-stable"
+ # Run tests
+ # TODO: Remove hacky chmod for BuildKite
+ - "chmod +x ./scripts/ci/*.sh"
+ - "chmod +x ./scripts/*"
+ - "./scripts/ci/install-deps.sh"
+ - "./scripts/ci/riot-unit-tests.sh"
+ env:
+ CHROME_BIN: "/usr/bin/google-chrome-stable"
+ plugins:
+ - docker#v3.0.1:
+ image: "node:10"
+ propagate-environment: true
diff --git a/.travis.yml b/.travis.yml
deleted file mode 100644
index ebf36658d5..0000000000
--- a/.travis.yml
+++ /dev/null
@@ -1,38 +0,0 @@
-# we need trusty for the chrome addon
-dist: trusty
-
-# we don't need sudo, so can run in a container, which makes startup much
-# quicker.
-#
-# unfortunately we do temporarily require sudo as a workaround for
-# https://github.com/travis-ci/travis-ci/issues/8836
-sudo: required
-
-language: node_js
-node_js:
- - node # Latest stable version of nodejs.
-addons:
- chrome: stable
-before_install:
- - curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --version 1.13.0
- - export PATH=$HOME/.yarn/bin:$PATH
-install:
- - ./scripts/travis/install-deps.sh
-matrix:
- include:
- - name: Linting Checks
- script:
- # run the linter, but exclude any files known to have errors or warnings.
- - yarn lintwithexclusions
- # - name: End-to-End Tests
- # if: branch = develop
- # install:
- # - sudo apt-get install build-essential python2.7-dev libffi-dev python-pip python-setuptools sqlite3 libssl-dev python-virtualenv libjpeg-dev libxslt1-dev
- # script:
- # - ./scripts/travis/end-to-end-tests.sh
- - name: Unit Tests
- script:
- - ./scripts/travis/unit-tests.sh
- - name: Riot-web Unit Tests
- script:
- - ./scripts/travis/riot-unit-tests.sh
diff --git a/karma.conf.js b/karma.conf.js
index 5e7fe76d56..b687be78fa 100644
--- a/karma.conf.js
+++ b/karma.conf.js
@@ -135,9 +135,10 @@ module.exports = function (config) {
],
customLaunchers: {
- 'ChromeHeadless': {
+ 'VectorChromeHeadless': {
base: 'Chrome',
flags: [
+ '--no-sandbox',
// See https://chromium.googlesource.com/chromium/src/+/lkgr/headless/README.md
'--headless',
'--disable-gpu',
diff --git a/package.json b/package.json
index 0fa4a829de..f1fb365a65 100644
--- a/package.json
+++ b/package.json
@@ -51,7 +51,7 @@
"lintwithexclusions": "eslint --max-warnings 0 --ignore-path .eslintignore.errorfiles src test",
"clean": "rimraf lib",
"prepare": "yarn clean && yarn build && git rev-parse HEAD > git-revision.txt",
- "test": "karma start --single-run=true --browsers ChromeHeadless",
+ "test": "karma start --single-run=true --browsers VectorChromeHeadless",
"test-multi": "karma start"
},
"dependencies": {
@@ -131,7 +131,7 @@
"flow-parser": "^0.57.3",
"jest-mock": "^23.2.0",
"karma": "^4.0.1",
- "karma-chrome-launcher": "^0.2.3",
+ "karma-chrome-launcher": "^2.2.0",
"karma-cli": "^1.0.1",
"karma-junit-reporter": "^2.0.0",
"karma-logcapture-reporter": "0.0.1",
diff --git a/res/css/views/avatars/_BaseAvatar.scss b/res/css/views/avatars/_BaseAvatar.scss
index ee2d9c190f..91b2d6c426 100644
--- a/res/css/views/avatars/_BaseAvatar.scss
+++ b/res/css/views/avatars/_BaseAvatar.scss
@@ -16,6 +16,16 @@ limitations under the License.
.mx_BaseAvatar {
position: relative;
+ // In at least Firefox, the case of relative positioned inline elements
+ // (such as mx_BaseAvatar) with absolute positioned children (such as
+ // mx_BaseAvatar_initial) is a dark corner full of spider webs. It will give
+ // different results during full reflow of the page vs. incremental reflow
+ // of small portions. While that's surely a browser bug, we can avoid it by
+ // using `inline-block` instead of the default `inline`.
+ // https://github.com/vector-im/riot-web/issues/5594
+ // https://bugzilla.mozilla.org/show_bug.cgi?id=1535053
+ // https://bugzilla.mozilla.org/show_bug.cgi?id=255139
+ display: inline-block;
}
.mx_BaseAvatar_initial {
diff --git a/res/css/views/rooms/_EntityTile.scss b/res/css/views/rooms/_EntityTile.scss
index 68a9d61edb..44528a5624 100644
--- a/res/css/views/rooms/_EntityTile.scss
+++ b/res/css/views/rooms/_EntityTile.scss
@@ -22,10 +22,20 @@ limitations under the License.
}
.mx_EntityTile:hover {
- background-image: url('$(res)/img/member_chevron.png');
- background-position: center right 10px;
- background-repeat: no-repeat;
padding-right: 30px;
+ position: relative; // to keep the chevron aligned
+}
+
+.mx_EntityTile:hover::before {
+ content: "";
+ position: absolute;
+ top: calc(50% - 8px); // center
+ right: 10px;
+ mask: url('$(res)/img/member_chevron.png');
+ mask-repeat: no-repeat;
+ width: 16px;
+ height: 16px;
+ background-color: $rightpanel-button-color;
}
.mx_EntityTile .mx_PresenceLabel {
@@ -92,19 +102,19 @@ limitations under the License.
.mx_EntityTile_unavailable .mx_EntityTile_avatar,
.mx_EntityTile_unavailable .mx_EntityTile_name,
.mx_EntityTile_offline_beenactive .mx_EntityTile_avatar,
-.mx_EntityTile_offline_beenactive .mx_EntityTile_name,
+.mx_EntityTile_offline_beenactive .mx_EntityTile_name
{
opacity: 0.5;
}
.mx_EntityTile_offline_neveractive .mx_EntityTile_avatar,
-.mx_EntityTile_offline_neveractive .mx_EntityTile_name,
+.mx_EntityTile_offline_neveractive .mx_EntityTile_name
{
opacity: 0.25;
}
.mx_EntityTile_unknown .mx_EntityTile_avatar,
-.mx_EntityTile_unknown .mx_EntityTile_name,
+.mx_EntityTile_unknown .mx_EntityTile_name
{
opacity: 0.25;
}
diff --git a/scripts/travis/build.sh b/scripts/ci/build.sh
old mode 100755
new mode 100644
similarity index 82%
rename from scripts/travis/build.sh
rename to scripts/ci/build.sh
index 862a3feaa9..0b1fa23093
--- a/scripts/travis/build.sh
+++ b/scripts/ci/build.sh
@@ -1,6 +1,6 @@
#!/bin/bash
#
-# script which is run by the travis build (after `yarn test`).
+# script which is run by the CI build (after `yarn test`).
#
# clones riot-web develop and runs the tests against our version of react-sdk.
diff --git a/scripts/travis/end-to-end-tests.sh b/scripts/ci/end-to-end-tests.sh
old mode 100755
new mode 100644
similarity index 84%
rename from scripts/travis/end-to-end-tests.sh
rename to scripts/ci/end-to-end-tests.sh
index 0c728be509..d0b1a30ce2
--- a/scripts/travis/end-to-end-tests.sh
+++ b/scripts/ci/end-to-end-tests.sh
@@ -1,6 +1,6 @@
#!/bin/bash
#
-# script which is run by the travis build (after `yarn test`).
+# script which is run by the CI build (after `yarn test`).
#
# clones riot-web develop and runs the tests against our version of react-sdk.
@@ -9,7 +9,7 @@ set -ev
RIOT_WEB_DIR=riot-web
REACT_SDK_DIR=`pwd`
-scripts/travis/build.sh
+scripts/ci/build.sh
# run end to end tests
scripts/fetchdep.sh matrix-org matrix-react-end-to-end-tests master
pushd matrix-react-end-to-end-tests
diff --git a/scripts/travis/install-deps.sh b/scripts/ci/install-deps.sh
old mode 100755
new mode 100644
similarity index 100%
rename from scripts/travis/install-deps.sh
rename to scripts/ci/install-deps.sh
diff --git a/scripts/travis/riot-unit-tests.sh b/scripts/ci/riot-unit-tests.sh
old mode 100755
new mode 100644
similarity index 65%
rename from scripts/travis/riot-unit-tests.sh
rename to scripts/ci/riot-unit-tests.sh
index ca53dc9268..215af13030
--- a/scripts/travis/riot-unit-tests.sh
+++ b/scripts/ci/riot-unit-tests.sh
@@ -1,6 +1,6 @@
#!/bin/bash
#
-# script which is run by the travis build (after `yarn test`).
+# script which is run by the CI build (after `yarn test`).
#
# clones riot-web develop and runs the tests against our version of react-sdk.
@@ -8,7 +8,7 @@ set -ev
RIOT_WEB_DIR=riot-web
-scripts/travis/build.sh
+scripts/ci/build.sh
pushd "$RIOT_WEB_DIR"
yarn test
popd
diff --git a/scripts/ci/unit-tests.sh b/scripts/ci/unit-tests.sh
new file mode 100644
index 0000000000..5b86190963
--- /dev/null
+++ b/scripts/ci/unit-tests.sh
@@ -0,0 +1,10 @@
+#!/bin/bash
+#
+# script which is run by the CI build (after `yarn test`).
+#
+# clones riot-web develop and runs the tests against our version of react-sdk.
+
+set -ev
+
+scripts/ci/build.sh
+yarn test
diff --git a/scripts/fetchdep.sh b/scripts/fetchdep.sh
index 95fc4b0603..6fb50e7cea 100755
--- a/scripts/fetchdep.sh
+++ b/scripts/fetchdep.sh
@@ -17,10 +17,11 @@ clone() {
fi
}
+
# Try the PR author's branch in case it exists on the deps as well.
-clone $TRAVIS_PULL_REQUEST_BRANCH
+clone $BUILDKITE_BRANCH
# Try the target branch of the push or PR.
-clone $TRAVIS_BRANCH
+clone $BUILDKITE_PULL_REQUEST_BASE_BRANCH
# Try the current branch from Jenkins.
clone `"echo $GIT_BRANCH" | sed -e 's/^origin\///'`
# Use the default branch as the last resort.
diff --git a/scripts/travis/unit-tests.sh b/scripts/travis/unit-tests.sh
deleted file mode 100755
index fe3e383c0a..0000000000
--- a/scripts/travis/unit-tests.sh
+++ /dev/null
@@ -1,10 +0,0 @@
-#!/bin/bash
-#
-# script which is run by the travis build (after `yarn test`).
-#
-# clones riot-web develop and runs the tests against our version of react-sdk.
-
-set -ev
-
-scripts/travis/build.sh
-CHROME_BIN='/usr/bin/google-chrome-stable' yarn test
diff --git a/src/components/structures/CustomRoomTagPanel.js b/src/components/structures/CustomRoomTagPanel.js
index 4e33f0a22d..d99204e40a 100644
--- a/src/components/structures/CustomRoomTagPanel.js
+++ b/src/components/structures/CustomRoomTagPanel.js
@@ -84,7 +84,7 @@ class CustomRoomTagTile extends React.Component {
render() {
const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
const AccessibleButton = sdk.getComponent('elements.AccessibleButton');
- const RoomTooltip = sdk.getComponent('rooms.RoomTooltip');
+ const Tooltip = sdk.getComponent('rooms.Tooltip');
const tag = this.props.tag;
const avatarHeight = 40;
@@ -103,7 +103,7 @@ class CustomRoomTagTile extends React.Component {
}
const tip = (this.state.hover ?
-