Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
converse.js
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
converse.js
Commits
c9b4c740
Commit
c9b4c740
authored
Jun 02, 2018
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Exploring using karma
parent
74eed32e
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
5656 additions
and
2388 deletions
+5656
-2388
.eslintrc.json
.eslintrc.json
+1
-0
dev.html
dev.html
+1
-5
karma.conf.js
karma.conf.js
+58
-0
package-lock.json
package-lock.json
+3732
-671
package.json
package.json
+10
-1
spec/messages.js
spec/messages.js
+1259
-1270
src/config.js
src/config.js
+1
-1
tests/index.html
tests/index.html
+2
-3
tests/mock.js
tests/mock.js
+154
-159
tests/runner.js
tests/runner.js
+173
-20
tests/utils.js
tests/utils.js
+253
-258
webpack.config.js
webpack.config.js
+12
-0
No files found.
.eslintrc.json
View file @
c9b4c740
...
@@ -9,6 +9,7 @@
...
@@ -9,6 +9,7 @@
"plugins"
:
[
"lodash"
],
"plugins"
:
[
"lodash"
],
"extends"
:
[
"eslint:recommended"
,
"plugin:lodash/canonical"
],
"extends"
:
[
"eslint:recommended"
,
"plugin:lodash/canonical"
],
"globals"
:
{
"globals"
:
{
"module"
:
true
,
"window"
:
true
,
"window"
:
true
,
"sinon"
:
true
,
"sinon"
:
true
,
"define"
:
true
,
"define"
:
true
,
...
...
dev.html
View file @
c9b4c740
...
@@ -11,11 +11,7 @@
...
@@ -11,11 +11,7 @@
<link
rel=
"shortcut icon"
type=
"image/ico"
href=
"css/images/favicon.ico"
/>
<link
rel=
"shortcut icon"
type=
"image/ico"
href=
"css/images/favicon.ico"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"css/fullpage.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"css/fullpage.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"css/converse.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"css/converse.css"
/>
<
![
if
gte
IE
11
]
>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"css/converse.css"
/>
<script
src=
"dist/converse.js"
></script>
<script
src=
"dist/converse.js"
></script>
<
![
endif
]
>
</head>
</head>
<body
class=
"reset"
>
<body
class=
"reset"
>
...
...
karma.conf.js
0 → 100644
View file @
c9b4c740
// Karma configuration
// Generated on Sat Jun 02 2018 22:33:35 GMT+0200 (CEST)
module
.
exports
=
function
(
config
)
{
config
.
set
({
// base path that will be used to resolve all patterns (eg. files, exclude)
basePath
:
''
,
// frameworks to use
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
frameworks
:
[
'
jasmine
'
],
// list of files / patterns to load in the browser
files
:
[
'
dist/converse.js
'
,
'
tests/utils.js
'
,
'
tests/mock.js
'
,
'
spec/messages.js
'
],
// list of files / patterns to exclude
exclude
:
[
'
*.min.js
'
],
// preprocess matching files before serving them to the browser
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
preprocessors
:
{},
// test results reporter to use
// possible values: 'dots', 'progress'
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
reporters
:
[
'
progress
'
],
// web server port
port
:
9876
,
// enable / disable colors in the output (reporters and logs)
colors
:
true
,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel
:
config
.
LOG_DEBUG
,
// enable / disable watching file and executing tests whenever any file changes
autoWatch
:
true
,
// start these browsers
// available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
browsers
:
[],
// Continuous Integration mode
// if true, Karma captures browsers, runs the tests and exits
singleRun
:
false
,
// Concurrency level
// how many browser should be started simultaneous
concurrency
:
Infinity
})
}
package-lock.json
View file @
c9b4c740
This source diff could not be displayed because it is too large. You can
view the blob
instead.
package.json
View file @
c9b4c740
...
@@ -58,18 +58,27 @@
...
@@ -58,18 +58,27 @@
"
jquery
"
:
"
3.2.1
"
,
"
jquery
"
:
"
3.2.1
"
,
"
jsdoc
"
:
"
^3.5.5
"
,
"
jsdoc
"
:
"
^3.5.5
"
,
"
jshint
"
:
"
^2.9.4
"
,
"
jshint
"
:
"
^2.9.4
"
,
"
karma
"
:
"
^2.0.2
"
,
"
karma-chrome-launcher
"
:
"
^2.2.0
"
,
"
karma-cli
"
:
"
^1.0.1
"
,
"
karma-firefox-launcher
"
:
"
^1.1.0
"
,
"
karma-jasmine
"
:
"
^1.1.2
"
,
"
karma-requirejs
"
:
"
^1.1.0
"
,
"
karma-webpack
"
:
"
^3.0.0
"
,
"
lodash
"
:
"
4.17.4
"
,
"
lodash
"
:
"
4.17.4
"
,
"
lodash-template-loader
"
:
"
^2.0.0
"
,
"
lodash-template-webpack-loader
"
:
"
jcbrand/lodash-template-webpack-loader
"
,
"
lodash-template-webpack-loader
"
:
"
jcbrand/lodash-template-webpack-loader
"
,
"
moment
"
:
"~> 2.19.3 "
,
"
moment
"
:
"~> 2.19.3 "
,
"
npm
"
:
"
^5.7.1
"
,
"
npm
"
:
"
^5.7.1
"
,
"
otr
"
:
"
0.2.16
"
,
"
otr
"
:
"
0.2.16
"
,
"
pluggable.js
"
:
"
2.0.0
"
,
"
pluggable.js
"
:
"
2.0.0
"
,
"
po2json
"
:
"
^0.4.4
"
,
"
po2json
"
:
"
^0.4.4
"
,
"
requirejs
"
:
"
2.3.5
"
,
"
run-headless-chromium
"
:
"
^0.1.1
"
,
"
run-headless-chromium
"
:
"
^0.1.1
"
,
"
sinon
"
:
"
^2.1.0
"
,
"
sinon
"
:
"
^2.1.0
"
,
"
sizzle
"
:
"
^2.3.3
"
,
"
sizzle
"
:
"
^2.3.3
"
,
"
snabbdom
"
:
"
0.7.1
"
,
"
snabbdom
"
:
"
0.7.1
"
,
"
strophe.js
"
:
"
1.2.1
4
"
,
"
strophe.js
"
:
"
1.2.1
5
"
,
"
strophejs-plugin-ping
"
:
"
0.0.1
"
,
"
strophejs-plugin-ping
"
:
"
0.0.1
"
,
"
strophejs-plugin-register
"
:
"
0.0.1
"
,
"
strophejs-plugin-register
"
:
"
0.0.1
"
,
"
strophejs-plugin-rsm
"
:
"
0.0.1
"
,
"
strophejs-plugin-rsm
"
:
"
0.0.1
"
,
...
...
spec/messages.js
View file @
c9b4c740
(
function
(
root
,
factory
)
{
"
use strict
"
;
define
([
var
_
=
converse
.
env
.
_
;
"
jquery
"
,
var
$iq
=
converse
.
env
.
$iq
;
"
jasmine
"
,
var
$msg
=
converse
.
env
.
$msg
;
"
utils
"
,
var
Strophe
=
converse
.
env
.
Strophe
;
"
converse-core
"
,
var
Promise
=
converse
.
env
.
Promise
;
"
mock
"
,
var
moment
=
converse
.
env
.
moment
;
"
test-utils
"
var
u
=
converse
.
env
.
utils
;
],
factory
);
}
(
this
,
function
(
$
,
jasmine
,
utils
,
converse
,
mock
,
test_utils
)
{
debugger
;
"
use strict
"
;
describe
(
"
A Chat Message
"
,
function
()
{
var
_
=
converse
.
env
.
_
;
var
$iq
=
converse
.
env
.
$iq
;
var
$msg
=
converse
.
env
.
$msg
;
var
Strophe
=
converse
.
env
.
Strophe
;
var
Promise
=
converse
.
env
.
Promise
;
var
moment
=
converse
.
env
.
moment
;
var
u
=
converse
.
env
.
utils
;
describe
(
"
A Chat Message
"
,
function
()
{
describe
(
"
when received from someone else
"
,
function
()
{
describe
(
"
when received from someone else
"
,
function
()
{
...
@@ -1483,5 +1473,4 @@
...
@@ -1483,5 +1473,4 @@
});
});
}));
}));
});
});
});
});
}));
src/config.js
View file @
c9b4c740
...
@@ -12,7 +12,7 @@ if (typeof(require) === 'undefined') {
...
@@ -12,7 +12,7 @@ if (typeof(require) === 'undefined') {
};
};
}
}
require
.
config
(
{
window
.
config
=
{
baseUrl
:
'
.
'
,
baseUrl
:
'
.
'
,
paths
:
{
paths
:
{
"
IPv6
"
:
"
node_modules/urijs/src/IPv6
"
,
"
IPv6
"
:
"
node_modules/urijs/src/IPv6
"
,
...
...
tests/index.html
View file @
c9b4c740
...
@@ -11,9 +11,8 @@
...
@@ -11,9 +11,8 @@
<link
rel=
"stylesheet"
type=
"text/css"
media=
"screen"
href=
"../css/jasmine.css"
>
<link
rel=
"stylesheet"
type=
"text/css"
media=
"screen"
href=
"../css/jasmine.css"
>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"../css/website.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"../css/website.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"../css/converse.css"
/>
<link
type=
"text/css"
rel=
"stylesheet"
media=
"screen"
href=
"../css/converse.css"
/>
<script
src=
"dist/converse.js"
></script>
<script
src=
"../src/config.js"
></script>
<script
src=
"runner.js"
></script>
<script
data-main=
"runner"
src=
"../node_modules/requirejs/require.js"
></script>
<style>
<style>
.tests-brand-heading
{
.tests-brand-heading
{
...
...
tests/mock.js
View file @
c9b4c740
(
function
(
root
,
factory
)
{
var
_
=
converse
.
env
.
_
;
define
(
"
mock
"
,
[
'
converse
'
],
factory
);
var
Promise
=
converse
.
env
.
Promise
;
}(
this
,
function
(
converse
)
{
var
Strophe
=
converse
.
env
.
Strophe
;
var
_
=
converse
.
env
.
_
;
var
$iq
=
converse
.
env
.
$iq
;
var
Promise
=
converse
.
env
.
Promise
;
window
.
mock
=
{};
var
Strophe
=
converse
.
env
.
Strophe
;
var
$iq
=
converse
.
env
.
$iq
;
var
mock
=
{};
mock
.
view_mode
=
'
overlayed
'
;
mock
.
view_mode
=
'
overlayed
'
;
// Names from http://www.fakenamegenerator.com/
// Names from http://www.fakenamegenerator.com/
mock
.
req_names
=
[
mock
.
req_names
=
[
'
Louw Spekman
'
,
'
Mohamad Stet
'
,
'
Dominik Beyer
'
'
Louw Spekman
'
,
'
Mohamad Stet
'
,
'
Dominik Beyer
'
];
];
mock
.
pend_names
=
[
mock
.
pend_names
=
[
'
Suleyman van Beusichem
'
,
'
Nanja van Yperen
'
,
'
Nicole Diederich
'
'
Suleyman van Beusichem
'
,
'
Nanja van Yperen
'
,
'
Nicole Diederich
'
];
];
mock
.
cur_names
=
[
mock
.
cur_names
=
[
'
Max Frankfurter
'
,
'
Candice van der Knijff
'
,
'
Irini Vlastuin
'
,
'
Rinse Sommer
'
,
'
Annegreet Gomez
'
,
'
Max Frankfurter
'
,
'
Candice van der Knijff
'
,
'
Irini Vlastuin
'
,
'
Rinse Sommer
'
,
'
Annegreet Gomez
'
,
'
Robin Schook
'
,
'
Marcel Eberhardt
'
,
'
Simone Brauer
'
,
'
Asmaa Haakman
'
,
'
Felix Amsel
'
,
'
Robin Schook
'
,
'
Marcel Eberhardt
'
,
'
Simone Brauer
'
,
'
Asmaa Haakman
'
,
'
Felix Amsel
'
,
'
Lena Grunewald
'
,
'
Laura Grunewald
'
,
'
Mandy Seiler
'
,
'
Sven Bosch
'
,
'
Nuriye Cuypers
'
'
Lena Grunewald
'
,
'
Laura Grunewald
'
,
'
Mandy Seiler
'
,
'
Sven Bosch
'
,
'
Nuriye Cuypers
'
];
];
mock
.
num_contacts
=
mock
.
req_names
.
length
+
mock
.
pend_names
.
length
+
mock
.
cur_names
.
length
;
mock
.
num_contacts
=
mock
.
req_names
.
length
+
mock
.
pend_names
.
length
+
mock
.
cur_names
.
length
;
mock
.
groups
=
{
mock
.
groups
=
{
'
colleagues
'
:
3
,
'
colleagues
'
:
3
,
'
friends & acquaintences
'
:
3
,
'
friends & acquaintences
'
:
3
,
'
Family
'
:
4
,
'
Family
'
:
4
,
'
ænemies
'
:
3
,
'
ænemies
'
:
3
,
'
Ungrouped
'
:
2
'
Ungrouped
'
:
2
};
};
mock
.
chatroom_names
=
[
mock
.
chatroom_names
=
[
'
Dyon van de Wege
'
,
'
Thomas Kalb
'
,
'
Dirk Theissen
'
,
'
Felix Hofmann
'
,
'
Ka Lek
'
,
'
Anne Ebersbacher
'
'
Dyon van de Wege
'
,
'
Thomas Kalb
'
,
'
Dirk Theissen
'
,
'
Felix Hofmann
'
,
'
Ka Lek
'
,
'
Anne Ebersbacher
'
];
];
// TODO: need to also test other roles and affiliations
// TODO: need to also test other roles and affiliations
mock
.
chatroom_roles
=
{
mock
.
chatroom_roles
=
{
'
Anne Ebersbacher
'
:
{
affiliation
:
"
owner
"
,
role
:
"
moderator
"
},
'
Anne Ebersbacher
'
:
{
affiliation
:
"
owner
"
,
role
:
"
moderator
"
},
'
Dirk Theissen
'
:
{
affiliation
:
"
admin
"
,
role
:
"
moderator
"
},
'
Dirk Theissen
'
:
{
affiliation
:
"
admin
"
,
role
:
"
moderator
"
},
'
Dyon van de Wege
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Dyon van de Wege
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Felix Hofmann
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Felix Hofmann
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Ka Lek
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Ka Lek
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
},
'
Thomas Kalb
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
}
'
Thomas Kalb
'
:
{
affiliation
:
"
member
"
,
role
:
"
occupant
"
}
};
};
mock
.
event
=
{
mock
.
event
=
{
'
preventDefault
'
:
function
()
{}
'
preventDefault
'
:
function
()
{}
};
};
mock
.
mock_connection
=
function
()
{
// eslint-disable-line wrap-iife
mock
.
mock_connection
=
function
()
{
// eslint-disable-line wrap-iife
return
function
()
{
return
function
()
{
Strophe
.
Bosh
.
prototype
.
_processRequest
=
function
()
{};
// Don't attempt to send out stanzas
Strophe
.
Bosh
.
prototype
.
_processRequest
=
function
()
{};
// Don't attempt to send out stanzas
var
c
=
new
Strophe
.
Connection
(
'
jasmine tests
'
);
var
c
=
new
Strophe
.
Connection
(
'
jasmine tests
'
);
...
@@ -72,9 +69,9 @@
...
@@ -72,9 +69,9 @@
};
};
return
c
;
return
c
;
};
};
}();
}();
function
initConverse
(
settings
,
spies
,
promises
)
{
function
initConverse
(
settings
,
spies
,
promises
)
{
window
.
localStorage
.
clear
();
window
.
localStorage
.
clear
();
window
.
sessionStorage
.
clear
();
window
.
sessionStorage
.
clear
();
...
@@ -137,9 +134,9 @@
...
@@ -137,9 +134,9 @@
}
}
window
.
converse_disable_effects
=
true
;
window
.
converse_disable_effects
=
true
;
return
_converse
;
return
_converse
;
}
}
mock
.
initConverseWithPromises
=
function
(
spies
,
promise_names
,
settings
,
func
)
{
mock
.
initConverseWithPromises
=
function
(
spies
,
promise_names
,
settings
,
func
)
{
return
function
(
done
)
{
return
function
(
done
)
{
var
_converse
=
initConverse
(
settings
,
spies
);
var
_converse
=
initConverse
(
settings
,
spies
);
var
promises
=
_
.
map
(
promise_names
,
_converse
.
api
.
waitUntil
);
var
promises
=
_
.
map
(
promise_names
,
_converse
.
api
.
waitUntil
);
...
@@ -147,15 +144,15 @@
...
@@ -147,15 +144,15 @@
.
then
(
_
.
partial
(
func
,
done
,
_converse
))
.
then
(
_
.
partial
(
func
,
done
,
_converse
))
.
catch
(
_
.
partial
(
_converse
.
log
,
_
,
Strophe
.
LogLevel
.
FATAL
));
.
catch
(
_
.
partial
(
_converse
.
log
,
_
,
Strophe
.
LogLevel
.
FATAL
));
}
}
};
};
mock
.
initConverseWithConnectionSpies
=
function
(
spies
,
settings
,
func
)
{
mock
.
initConverseWithConnectionSpies
=
function
(
spies
,
settings
,
func
)
{
return
function
(
done
)
{
return
function
(
done
)
{
return
func
(
done
,
initConverse
(
settings
,
spies
));
return
func
(
done
,
initConverse
(
settings
,
spies
));
};
};
};
};
mock
.
initConverseWithAsync
=
function
(
settings
,
func
)
{
mock
.
initConverseWithAsync
=
function
(
settings
,
func
)
{
if
(
_
.
isFunction
(
settings
))
{
if
(
_
.
isFunction
(
settings
))
{
var
_func
=
settings
;
var
_func
=
settings
;
settings
=
func
;
settings
=
func
;
...
@@ -164,8 +161,8 @@
...
@@ -164,8 +161,8 @@
return
function
(
done
)
{
return
function
(
done
)
{
return
func
(
done
,
initConverse
(
settings
));
return
func
(
done
,
initConverse
(
settings
));
};
};
};
};
mock
.
initConverse
=
function
(
settings
,
func
)
{
mock
.
initConverse
=
function
(
settings
,
func
)
{
if
(
_
.
isFunction
(
settings
))
{
if
(
_
.
isFunction
(
settings
))
{
var
_func
=
settings
;
var
_func
=
settings
;
settings
=
func
;
settings
=
func
;
...
@@ -174,6 +171,4 @@
...
@@ -174,6 +171,4 @@
return
function
()
{
return
function
()
{
return
func
(
initConverse
(
settings
));
return
func
(
initConverse
(
settings
));
};
};
};
};
return
mock
;
}));
tests/runner.js
View file @
c9b4c740
/*global config */
var
config
=
{
baseUrl
:
'
/base/
'
,
paths
:
{
"
console-reporter
"
:
"
tests/console-reporter
"
,
"
IPv6
"
:
"
node_modules/urijs/src/IPv6
"
,
"
SecondLevelDomains
"
:
"
node_modules/urijs/src/SecondLevelDomains
"
,
"
almond
"
:
"
node_modules/almond/almond
"
,
"
awesomplete
"
:
"
node_modules/awesomplete-avoid-xss/awesomplete
"
,
"
babel
"
:
"
node_modules/requirejs-babel/babel-5.8.34.min
"
,
"
backbone
"
:
"
node_modules/backbone/backbone
"
,
"
backbone.browserStorage
"
:
"
node_modules/backbone.browserStorage/backbone.browserStorage
"
,
"
backbone.nativeview
"
:
"
node_modules/backbone.nativeview/backbone.nativeview
"
,
"
backbone.noconflict
"
:
"
src/backbone.noconflict
"
,
"
backbone.orderedlistview
"
:
"
node_modules/backbone.overview/dist/backbone.orderedlistview
"
,
"
backbone.overview
"
:
"
node_modules/backbone.overview/dist/backbone.overview
"
,
"
backbone.vdomview
"
:
"
node_modules/backbone.vdomview/dist/backbone.vdomview
"
,
"
bootstrap
"
:
"
node_modules/bootstrap.native/dist/bootstrap-native-v4
"
,
"
emojione
"
:
"
node_modules/emojione/lib/js/emojione
"
,
"
es6-promise
"
:
"
node_modules/es6-promise/dist/es6-promise.auto
"
,
"
eventemitter
"
:
"
node_modules/otr/build/dep/eventemitter
"
,
"
filesize
"
:
"
node_modules/filesize/lib/filesize
"
,
"
form-utils
"
:
"
src/utils/form
"
,
"
i18n
"
:
"
src/i18n
"
,
"
jed
"
:
"
node_modules/jed/jed
"
,
"
jquery
"
:
"
src/jquery-stub
"
,
"
lodash
"
:
"
node_modules/lodash/lodash
"
,
"
lodash.converter
"
:
"
3rdparty/lodash.fp
"
,
"
lodash.fp
"
:
"
src/lodash.fp
"
,
"
lodash.noconflict
"
:
"
src/lodash.noconflict
"
,
"
message-utils
"
:
"
src/utils/message
"
,
"
muc-utils
"
:
"
src/utils/muc
"
,
"
pluggable
"
:
"
node_modules/pluggable.js/dist/pluggable
"
,
"
polyfill
"
:
"
src/polyfill
"
,
"
punycode
"
:
"
node_modules/urijs/src/punycode
"
,
"
sizzle
"
:
"
node_modules/sizzle/dist/sizzle
"
,
"
snabbdom
"
:
"
node_modules/snabbdom/dist/snabbdom
"
,
"
snabbdom-attributes
"
:
"
node_modules/snabbdom/dist/snabbdom-attributes
"
,
"
snabbdom-class
"
:
"
node_modules/snabbdom/dist/snabbdom-class
"
,
"
snabbdom-dataset
"
:
"
node_modules/snabbdom/dist/snabbdom-dataset
"
,
"
snabbdom-eventlisteners
"
:
"
node_modules/snabbdom/dist/snabbdom-eventlisteners
"
,
"
snabbdom-props
"
:
"
node_modules/snabbdom/dist/snabbdom-props
"
,
"
snabbdom-style
"
:
"
node_modules/snabbdom/dist/snabbdom-style
"
,
"
strophe
"
:
"
node_modules/strophe.js/strophe
"
,
"
strophe.ping
"
:
"
node_modules/strophejs-plugin-ping/strophe.ping
"
,
"
strophe.rsm
"
:
"
node_modules/strophejs-plugin-rsm/strophe.rsm
"
,
"
text
"
:
"
node_modules/text/text
"
,
"
tovnode
"
:
"
node_modules/snabbdom/dist/tovnode
"
,
"
tpl
"
:
"
node_modules/lodash-template-loader/loader
"
,
"
underscore
"
:
"
src/underscore-shim
"
,
"
uri
"
:
"
node_modules/urijs/src/URI
"
,
"
utils
"
:
"
src/utils/core
"
,
"
vdom-parser
"
:
"
node_modules/vdom-parser/dist
"
,
"
xss
"
:
"
node_modules/xss/dist/xss
"
,
"
xss.noconflict
"
:
"
src/xss.noconflict
"
,
// Converse
"
converse
"
:
"
src/converse
"
,
"
converse-bookmarks
"
:
"
src/converse-bookmarks
"
,
"
converse-chatboxes
"
:
"
src/converse-chatboxes
"
,
"
converse-caps
"
:
"
src/converse-caps
"
,
"
converse-chatview
"
:
"
src/converse-chatview
"
,
"
converse-controlbox
"
:
"
src/converse-controlbox
"
,
"
converse-core
"
:
"
src/converse-core
"
,
"
converse-disco
"
:
"
src/converse-disco
"
,
"
converse-dragresize
"
:
"
src/converse-dragresize
"
,
"
converse-embedded
"
:
"
src/converse-embedded
"
,
"
converse-fullscreen
"
:
"
src/converse-fullscreen
"
,
"
converse-headline
"
:
"
src/converse-headline
"
,
"
converse-mam
"
:
"
src/converse-mam
"
,
"
converse-message-view
"
:
"
src/converse-message-view
"
,
"
converse-minimize
"
:
"
src/converse-minimize
"
,
"
converse-modal
"
:
"
src/converse-modal
"
,
"
converse-muc
"
:
"
src/converse-muc
"
,
"
converse-muc-views
"
:
"
src/converse-muc-views
"
,
"
converse-notification
"
:
"
src/converse-notification
"
,
"
converse-otr
"
:
"
src/converse-otr
"
,
"
converse-ping
"
:
"
src/converse-ping
"
,
"
converse-profile
"
:
"
src/converse-profile
"
,
"
converse-register
"
:
"
src/converse-register
"
,
"
converse-roomslist
"
:
"
src/converse-roomslist
"
,
"
converse-roster
"
:
"
src/converse-roster
"
,
"
converse-rosterview
"
:
"
src/converse-rosterview
"
,
"
converse-singleton
"
:
"
src/converse-singleton
"
,
"
converse-vcard
"
:
"
src/converse-vcard
"
,
// Off-the-record-encryption
// "bigint": "node_modules/otr/build/dep/bigint",
"
bigint
"
:
"
3rdparty/bigint
"
,
"
crypto
"
:
"
node_modules/otr/build/dep/crypto
"
,
"
salsa20
"
:
"
node_modules/otr/build/dep/salsa20
"
,
"
otr
"
:
"
node_modules/otr/build/otr
"
,
},
packages
:
[{
'
name
'
:
'
moment
'
,
'
location
'
:
'
node_modules/moment
'
,
'
main
'
:
'
moment
'
}],
map
:
{
// '*' means all modules will get the '*.noconflict' version
// as their dependency.
'
*
'
:
{
'
backbone
'
:
'
backbone.noconflict
'
,
'
lodash
'
:
'
lodash.noconflict
'
},
// '*.noconflict' wants the real module
// If this line was not here, there would
// be an unresolvable cyclic dependency.
'
backbone.noconflict
'
:
{
'
backbone
'
:
'
backbone
'
},
'
lodash.noconflict
'
:
{
'
lodash
'
:
'
lodash
'
}
},
lodashLoader
:
{
// Configuration for requirejs-tpl
// Use Mustache style syntax for variable interpolation
root
:
"
src/templates/
"
,
templateSettings
:
{
"
escape
"
:
/
\
{
\
{
\
{([
\
s
\
S
]
+
?)
\
}
\
}
\
}
/g
,
"
evaluate
"
:
/
\{\[([\s\S]
+
?)\]\}
/g
,
"
interpolate
"
:
/
\
{
\
{([
\
s
\
S
]
+
?)
\
}
\
}
/g
,
// By default, template places the values from your data in the
// local scope via the with statement. However, you can specify
// a single variable name with the variable setting. This can
// significantly improve the speed at which a template is able
// to render.
"
variable
"
:
'
o
'
}
},
// define module dependencies for modules not using define
shim
:
{
'
backbone.orderedlistview
'
:
{
deps
:
[
'
backbone.nativeview
'
]
},
'
backbone.overview
'
:
{
deps
:
[
'
backbone.nativeview
'
]
},
'
backbone.vdomview
'
:
{
deps
:
[
'
backbone.nativeview
'
]
},
'
awesomplete
'
:
{
exports
:
'
Awesomplete
'
},
'
emojione
'
:
{
exports
:
'
emojione
'
},
'
xss
'
:
{
'
init
'
:
function
(
xss_noconflict
)
{
return
{
filterXSS
:
window
.
filterXSS
,
filterCSS
:
window
.
filterCSS
}
}
}
}
};
// Extra test dependencies
// Extra test dependencies
config
.
baseUrl
=
'
../
'
;
config
.
paths
.
jquery
=
"
node_modules/jquery/dist/jquery
"
;
config
.
paths
.
jquery
=
"
node_modules/jquery/dist/jquery
"
;
config
.
paths
.
mock
=
"
tests/mock
"
;
config
.
paths
.
mock
=
"
tests/mock
"
;
config
.
paths
[
'
wait-until-promise
'
]
=
"
node_modules/wait-until-promise/index
"
;
config
.
paths
[
'
wait-until-promise
'
]
=
"
node_modules/wait-until-promise/index
"
;
...
@@ -11,7 +159,6 @@ config.paths.transcripts = "converse-logs/converse-logs";
...
@@ -11,7 +159,6 @@ config.paths.transcripts = "converse-logs/converse-logs";
config
.
paths
[
"
jasmine-core
"
]
=
"
node_modules/jasmine-core/lib/jasmine-core/jasmine
"
;
config
.
paths
[
"
jasmine-core
"
]
=
"
node_modules/jasmine-core/lib/jasmine-core/jasmine
"
;
config
.
paths
.
jasmine
=
"
node_modules/jasmine-core/lib/jasmine-core/boot
"
;
config
.
paths
.
jasmine
=
"
node_modules/jasmine-core/lib/jasmine-core/boot
"
;
config
.
paths
[
"
jasmine-console
"
]
=
"
node_modules/jasmine-core/lib/console/console
"
;
config
.
paths
[
"
jasmine-console
"
]
=
"
node_modules/jasmine-core/lib/console/console
"
;
config
.
paths
[
"
console-reporter
"
]
=
"
tests/console-reporter
"
;
config
.
paths
[
"
jasmine-html
"
]
=
"
node_modules/jasmine-core/lib/jasmine-core/jasmine-html
"
;
config
.
paths
[
"
jasmine-html
"
]
=
"
node_modules/jasmine-core/lib/jasmine-core/jasmine-html
"
;
config
.
shim
.
jasmine
=
{
config
.
shim
.
jasmine
=
{
exports
:
'
window.jasmineRequire
'
exports
:
'
window.jasmineRequire
'
...
@@ -28,7 +175,7 @@ config.shim.jasmine = {
...
@@ -28,7 +175,7 @@ config.shim.jasmine = {
deps
:
[
'
jasmine-core
'
,
'
jasmine-html
'
,
'
jasmine-console
'
],
deps
:
[
'
jasmine-core
'
,
'
jasmine-html
'
,
'
jasmine-console
'
],
exports
:
'
window.jasmine
'
exports
:
'
window.jasmine
'
};
};
require
.
config
(
config
);
var
specs
=
[
var
specs
=
[
"
jasmine
"
,
"
jasmine
"
,
...
@@ -61,20 +208,26 @@ var specs = [
...
@@ -61,20 +208,26 @@ var specs = [
"
spec/http-file-upload
"
"
spec/http-file-upload
"
];
];
require
([
'
console-reporter
'
,
'
mock
'
,
'
sinon
'
,
'
wait-until-promise
'
,
'
pluggable
'
],
config
.
deps
=
specs
;
function
(
ConsoleReporter
,
mock
,
sinon
,
waitUntilPromise
,
pluggable
)
{
config
.
callback
=
window
.
__karma__
.
start
;
if
(
config
.
view_mode
)
{
require
.
config
(
config
);
mock
.
view_mode
=
config
.
view_mode
;
}
// require(['console-reporter', 'mock', 'sinon', 'wait-until-promise', 'pluggable'],
window
.
sinon
=
sinon
;
// function(ConsoleReporter, mock, sinon, waitUntilPromise, pluggable) {
window
.
waitUntilPromise
=
waitUntilPromise
.
default
;
//
window
.
localStorage
.
clear
();
// debugger;
window
.
sessionStorage
.
clear
();
// if (config.view_mode) {
// Load the specs
// mock.view_mode = config.view_mode;
require
(
specs
,
function
(
jasmine
)
{
// }
var
jasmineEnv
=
jasmine
.
getEnv
();
// window.sinon = sinon;
jasmineEnv
.
addReporter
(
new
ConsoleReporter
());
// window.waitUntilPromise = waitUntilPromise.default;
window
.
onload
();
// window.localStorage.clear();
});
// window.sessionStorage.clear();
});
// // Load the specs
// require(specs, function (jasmine) {
// var jasmineEnv = jasmine.getEnv();
// jasmineEnv.addReporter(new ConsoleReporter());
// window.onload();
// });
// });
tests/utils.js
View file @
c9b4c740
(
function
(
root
,
factory
)
{
var
_
=
converse
.
env
.
_
;
define
([
'
converse
'
,
'
es6-promise
'
,
'
mock
'
,
'
wait-until-promise
'
],
factory
);
var
$msg
=
converse
.
env
.
$msg
;
}(
this
,
function
(
converse_api
,
Promise
,
mock
,
waitUntilPromise
)
{
var
$pres
=
converse
.
env
.
$pres
;
var
_
=
converse_api
.
env
.
_
;
var
$iq
=
converse
.
env
.
$iq
;
var
$msg
=
converse_api
.
env
.
$msg
;
var
Strophe
=
converse
.
env
.
Strophe
;
var
$pres
=
converse_api
.
env
.
$pres
;
var
u
=
converse
.
env
.
utils
;
var
$iq
=
converse_api
.
env
.
$iq
;
var
utils
=
{};
var
Strophe
=
converse_api
.
env
.
Strophe
;
var
u
=
converse_api
.
env
.
utils
;
var
utils
=
{};
if
(
typeof
window
.
Promise
===
'
undefined
'
)
{
if
(
typeof
window
.
Promise
===
'
undefined
'
)
{
waitUntilPromise
.
setPromiseImplementation
(
Promise
);
waitUntilPromise
.
setPromiseImplementation
(
Promise
);
}
}
utils
.
waitUntil
=
waitUntilPromise
.
default
;
utils
.
waitUntil
=
waitUntilPromise
.
default
;
utils
.
waitUntilDiscoConfirmed
=
function
(
_converse
,
entity_jid
,
identities
,
features
,
items
,
type
)
{
utils
.
waitUntilDiscoConfirmed
=
function
(
_converse
,
entity_jid
,
identities
,
features
,
items
,
type
)
{
if
(
_
.
isNil
(
type
))
{
if
(
_
.
isNil
(
type
))
{
type
=
'
info
'
;
type
=
'
info
'
;
}
}
...
@@ -45,9 +42,9 @@
...
@@ -45,9 +42,9 @@
});
});
_converse
.
connection
.
_dataRecv
(
utils
.
createRequest
(
stanza
));
_converse
.
connection
.
_dataRecv
(
utils
.
createRequest
(
stanza
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}
}
utils
.
createRequest
=
function
(
iq
)
{
utils
.
createRequest
=
function
(
iq
)
{
iq
=
typeof
iq
.
tree
==
"
function
"
?
iq
.
tree
()
:
iq
;
iq
=
typeof
iq
.
tree
==
"
function
"
?
iq
.
tree
()
:
iq
;
var
req
=
new
Strophe
.
Request
(
iq
,
function
()
{});
var
req
=
new
Strophe
.
Request
(
iq
,
function
()
{});
req
.
getResponse
=
function
()
{
req
.
getResponse
=
function
()
{
...
@@ -56,18 +53,18 @@
...
@@ -56,18 +53,18 @@
return
env
;
return
env
;
};
};
return
req
;
return
req
;
};
};
utils
.
closeAllChatBoxes
=
function
(
converse
)
{
utils
.
closeAllChatBoxes
=
function
(
converse
)
{
var
i
,
chatbox
;
var
i
,
chatbox
;
for
(
i
=
converse
.
chatboxes
.
models
.
length
-
1
;
i
>-
1
;
i
--
)
{
for
(
i
=
converse
.
chatboxes
.
models
.
length
-
1
;
i
>-
1
;
i
--
)
{
chatbox
=
converse
.
chatboxes
.
models
[
i
];
chatbox
=
converse
.
chatboxes
.
models
[
i
];
converse
.
chatboxviews
.
get
(
chatbox
.
get
(
'
id
'
)).
close
();
converse
.
chatboxviews
.
get
(
chatbox
.
get
(
'
id
'
)).
close
();
}
}
return
this
;
return
this
;
};
};
utils
.
openControlBox
=
function
()
{
utils
.
openControlBox
=
function
()
{
var
toggle
=
document
.
querySelector
(
"
.toggle-controlbox
"
);
var
toggle
=
document
.
querySelector
(
"
.toggle-controlbox
"
);
if
(
!
u
.
isVisible
(
document
.
querySelector
(
"
#controlbox
"
)))
{
if
(
!
u
.
isVisible
(
document
.
querySelector
(
"
#controlbox
"
)))
{
if
(
!
u
.
isVisible
(
toggle
))
{
if
(
!
u
.
isVisible
(
toggle
))
{
...
@@ -76,9 +73,9 @@
...
@@ -76,9 +73,9 @@
toggle
.
click
();
toggle
.
click
();
}
}
return
this
;
return
this
;
};
};
utils
.
closeControlBox
=
function
()
{
utils
.
closeControlBox
=
function
()
{
var
controlbox
=
document
.
querySelector
(
"
#controlbox
"
);
var
controlbox
=
document
.
querySelector
(
"
#controlbox
"
);
if
(
u
.
isVisible
(
controlbox
))
{
if
(
u
.
isVisible
(
controlbox
))
{
var
button
=
controlbox
.
querySelector
(
"
.close-chatbox-button
"
);
var
button
=
controlbox
.
querySelector
(
"
.close-chatbox-button
"
);
...
@@ -87,22 +84,22 @@
...
@@ -87,22 +84,22 @@
}
}
}
}
return
this
;
return
this
;
};
};
utils
.
openChatBoxes
=
function
(
converse
,
amount
)
{
utils
.
openChatBoxes
=
function
(
converse
,
amount
)
{
var
i
=
0
,
jid
,
views
=
[];
var
i
=
0
,
jid
,
views
=
[];
for
(
i
;
i
<
amount
;
i
++
)
{
for
(
i
;
i
<
amount
;
i
++
)
{
jid
=
mock
.
cur_names
[
i
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
jid
=
mock
.
cur_names
[
i
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
views
[
i
]
=
converse
.
roster
.
get
(
jid
).
trigger
(
"
open
"
);
views
[
i
]
=
converse
.
roster
.
get
(
jid
).
trigger
(
"
open
"
);
}
}
return
views
;
return
views
;
};
};
utils
.
openChatBoxFor
=
function
(
converse
,
jid
)
{
utils
.
openChatBoxFor
=
function
(
converse
,
jid
)
{
return
converse
.
roster
.
get
(
jid
).
trigger
(
"
open
"
);
return
converse
.
roster
.
get
(
jid
).
trigger
(
"
open
"
);
};
};
utils
.
openChatRoomViaModal
=
function
(
_converse
,
jid
,
nick
)
{
utils
.
openChatRoomViaModal
=
function
(
_converse
,
jid
,
nick
)
{
// Opens a new chatroom
// Opens a new chatroom
return
new
Promise
(
function
(
resolve
,
reject
)
{
return
new
Promise
(
function
(
resolve
,
reject
)
{
utils
.
openControlBox
(
_converse
);
utils
.
openControlBox
(
_converse
);
...
@@ -118,13 +115,13 @@
...
@@ -118,13 +115,13 @@
resolve
();
resolve
();
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
};
};
utils
.
openChatRoom
=
function
(
_converse
,
room
,
server
,
nick
)
{
utils
.
openChatRoom
=
function
(
_converse
,
room
,
server
,
nick
)
{
_converse
.
api
.
rooms
.
open
(
`
${
room
}
@
${
server
}
`
);
_converse
.
api
.
rooms
.
open
(
`
${
room
}
@
${
server
}
`
);
};
};
utils
.
openAndEnterChatRoom
=
function
(
_converse
,
room
,
server
,
nick
)
{
utils
.
openAndEnterChatRoom
=
function
(
_converse
,
room
,
server
,
nick
)
{
let
last_stanza
;
let
last_stanza
;
return
new
Promise
(
function
(
resolve
,
reject
)
{
return
new
Promise
(
function
(
resolve
,
reject
)
{
...
@@ -181,22 +178,22 @@
...
@@ -181,22 +178,22 @@
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
}).
catch
(
_
.
partial
(
console
.
error
,
_
));
};
};
utils
.
clearBrowserStorage
=
function
()
{
utils
.
clearBrowserStorage
=
function
()
{
window
.
localStorage
.
clear
();
window
.
localStorage
.
clear
();
window
.
sessionStorage
.
clear
();
window
.
sessionStorage
.
clear
();
return
this
;
return
this
;
};
};
utils
.
clearChatBoxMessages
=
function
(
converse
,
jid
)
{
utils
.
clearChatBoxMessages
=
function
(
converse
,
jid
)
{
var
view
=
converse
.
chatboxviews
.
get
(
jid
);
var
view
=
converse
.
chatboxviews
.
get
(
jid
);
view
.
el
.
querySelector
(
'
.chat-content
'
).
innerHTML
=
''
;
view
.
el
.
querySelector
(
'
.chat-content
'
).
innerHTML
=
''
;
view
.
model
.
messages
.
reset
();
view
.
model
.
messages
.
reset
();
view
.
model
.
messages
.
browserStorage
.
_clear
();
view
.
model
.
messages
.
browserStorage
.
_clear
();
};
};
utils
.
createContacts
=
function
(
converse
,
type
,
length
)
{
utils
.
createContacts
=
function
(
converse
,
type
,
length
)
{
/* Create current (as opposed to requesting or pending) contacts
/* Create current (as opposed to requesting or pending) contacts
* for the user's roster.
* for the user's roster.
*
*
...
@@ -243,9 +240,9 @@
...
@@ -243,9 +240,9 @@
}
}
}
}
return
this
;
return
this
;
};
};
utils
.
createGroupedContacts
=
function
(
converse
)
{
utils
.
createGroupedContacts
=
function
(
converse
)
{
/* Create grouped contacts
/* Create grouped contacts
*/
*/
var
i
=
0
,
j
=
0
;
var
i
=
0
,
j
=
0
;
...
@@ -261,9 +258,9 @@
...
@@ -261,9 +258,9 @@
});
});
}
}
});
});
};
};
utils
.
createChatMessage
=
function
(
_converse
,
sender_jid
,
message
)
{
utils
.
createChatMessage
=
function
(
_converse
,
sender_jid
,
message
)
{
return
$msg
({
return
$msg
({
from
:
sender_jid
,
from
:
sender_jid
,
to
:
_converse
.
connection
.
jid
,
to
:
_converse
.
connection
.
jid
,
...
@@ -272,15 +269,13 @@
...
@@ -272,15 +269,13 @@
})
})
.
c
(
'
body
'
).
t
(
message
).
up
()
.
c
(
'
body
'
).
t
(
message
).
up
()
.
c
(
'
active
'
,
{
'
xmlns
'
:
Strophe
.
NS
.
CHATSTATES
}).
tree
();
.
c
(
'
active
'
,
{
'
xmlns
'
:
Strophe
.
NS
.
CHATSTATES
}).
tree
();
}
}
utils
.
sendMessage
=
function
(
chatboxview
,
message
)
{
utils
.
sendMessage
=
function
(
chatboxview
,
message
)
{
chatboxview
.
el
.
querySelector
(
'
.chat-textarea
'
).
value
=
message
;
chatboxview
.
el
.
querySelector
(
'
.chat-textarea
'
).
value
=
message
;
chatboxview
.
keyPressed
({
chatboxview
.
keyPressed
({
target
:
chatboxview
.
el
.
querySelector
(
'
textarea.chat-textarea
'
),
target
:
chatboxview
.
el
.
querySelector
(
'
textarea.chat-textarea
'
),
preventDefault
:
_
.
noop
,
preventDefault
:
_
.
noop
,
keyCode
:
13
keyCode
:
13
});
});
};
};
return
utils
;
}));
webpack.config.js
View file @
c9b4c740
...
@@ -75,6 +75,18 @@ const config = {
...
@@ -75,6 +75,18 @@ const config = {
path
.
resolve
(
__dirname
,
"
src
"
),
path
.
resolve
(
__dirname
,
"
src
"
),
],
],
alias
:
{
alias
:
{
"
jquery
"
:
path
.
resolve
(
__dirname
,
"
node_modules/jquery/dist/jquery
"
),
"
mock
"
:
path
.
resolve
(
__dirname
,
"
tests/mock
"
),
"
wait-until-promise
"
:
path
.
resolve
(
__dirname
,
"
node_modules/wait-until-promise/index
"
),
"
test-utils
"
:
path
.
resolve
(
__dirname
,
"
tests/utils
"
),
"
sinon
"
:
path
.
resolve
(
__dirname
,
"
node_modules/sinon/pkg/sinon
"
),
"
transcripts
"
:
path
.
resolve
(
__dirname
,
"
converse-logs/converse-logs
"
),
"
jasmine-core
"
:
path
.
resolve
(
__dirname
,
"
node_modules/jasmine-core/lib/jasmine-core/jasmine
"
),
"
jasmine
"
:
path
.
resolve
(
__dirname
,
"
node_modules/jasmine-core/lib/jasmine-core/boot
"
),
"
jasmine-console
"
:
path
.
resolve
(
__dirname
,
"
node_modules/jasmine-core/lib/console/console
"
),
"
console-reporter
"
:
path
.
resolve
(
__dirname
,
"
tests/console-reporter
"
),
"
jasmine-html
"
:
path
.
resolve
(
__dirname
,
"
node_modules/jasmine-core/lib/jasmine-core/jasmine-html
"
),
"
IPv6
"
:
path
.
resolve
(
__dirname
,
"
node_modules/urijs/src/IPv6
"
),
"
IPv6
"
:
path
.
resolve
(
__dirname
,
"
node_modules/urijs/src/IPv6
"
),
"
SecondLevelDomains
"
:
path
.
resolve
(
__dirname
,
"
node_modules/urijs/src/SecondLevelDomains
"
),
"
SecondLevelDomains
"
:
path
.
resolve
(
__dirname
,
"
node_modules/urijs/src/SecondLevelDomains
"
),
"
awesomplete
"
:
path
.
resolve
(
__dirname
,
"
node_modules/awesomplete-avoid-xss/awesomplete
"
),
"
awesomplete
"
:
path
.
resolve
(
__dirname
,
"
node_modules/awesomplete-avoid-xss/awesomplete
"
),
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment