Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
todomvc
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
Eugene Shen
todomvc
Commits
e128a635
Commit
e128a635
authored
Oct 08, 2015
by
Sam Saccone
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add automatic memory leak detection tests
parent
1a667088
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
163 additions
and
65 deletions
+163
-65
tests/allTests.js
tests/allTests.js
+4
-64
tests/framework-path-lookup.js
tests/framework-path-lookup.js
+62
-0
tests/memory.js
tests/memory.js
+94
-0
tests/package.json
tests/package.json
+2
-1
tests/run.sh
tests/run.sh
+1
-0
No files found.
tests/allTests.js
View file @
e128a635
'
use strict
'
;
'
use strict
'
;
var
testSuite
=
require
(
'
./test.js
'
);
var
testSuite
=
require
(
'
./test.js
'
);
var
fs
=
require
(
'
fs
'
);
var
argv
=
require
(
'
optimist
'
).
default
(
'
laxMode
'
,
false
).
default
(
'
browser
'
,
'
chrome
'
).
argv
;
var
argv
=
require
(
'
optimist
'
).
default
(
'
laxMode
'
,
false
).
default
(
'
browser
'
,
'
chrome
'
).
argv
;
var
frameworkPathLookup
=
require
(
'
./framework-path-lookup
'
);
var
rootUrl
=
'
http://localhost:8000/
'
;
var
rootUrl
=
'
http://localhost:8000/
'
;
var
frameworkNamePattern
=
/^
[
a-z-_
\d]
+$/
;
var
excludedFrameworks
=
[
var
list
=
frameworkPathLookup
(
argv
.
framework
);
// this implementation deviates from the specification to such an extent that they are
// not worth testing via a generic mechanism
'
gwt
'
,
// these implementations cannot be run offline, because they are hosted
'
firebase-angular
'
,
'
meteor
'
,
'
socketstream
'
,
// YUI is a special case here, it is not hosted, but fetches JS files dynamically
'
yui
'
,
// these frameworks take a long time to start-up, and there is no easy way to determine when they are ready
'
cujo
'
,
// sammyjs fails intermittently, it would appear that its state is sometimes updated asynchronously?
'
sammyjs
'
,
// elm-html batches UI updates with requestAnimationFrame which the tests
// don't wait for
'
elm
'
,
// these are examples that have been removed or are empty folders
'
emberjs_require
'
,
'
dermis
'
];
// collect together the framework names from each of the subfolders
if
(
list
.
length
===
0
)
{
var
list
=
fs
.
readdirSync
(
'
../examples/
'
)
.
map
(
function
(
folderName
)
{
return
{
name
:
folderName
,
path
:
'
examples/
'
+
folderName
};
});
// apps that are not hosted at the root of their folder need to be handled explicitly
var
exceptions
=
[
{
name
:
'
chaplin-brunch
'
,
path
:
'
examples/chaplin-brunch/public
'
},
{
name
:
'
angular-dart
'
,
path
:
'
examples/angular-dart/web
'
},
{
name
:
'
duel
'
,
path
:
'
examples/duel/www
'
},
{
name
:
'
vanilladart
'
,
path
:
'
examples/vanilladart/build/web
'
},
{
name
:
'
canjs_require
'
,
path
:
'
examples/canjs_require/
'
},
{
name
:
'
troopjs
'
,
path
:
'
examples/troopjs_require/
'
},
{
name
:
'
thorax_lumbar
'
,
path
:
'
examples/thorax_lumbar/public
'
}
];
list
=
list
.
map
(
function
(
framework
)
{
var
exception
=
exceptions
.
filter
(
function
(
exFramework
)
{
return
exFramework
.
name
===
framework
.
name
;
});
return
exception
.
length
>
0
?
exception
[
0
]
:
framework
;
});
// filter out any folders that are not frameworks (.e.g hidden files)
list
=
list
.
filter
(
function
(
framework
)
{
return
frameworkNamePattern
.
test
(
framework
.
name
);
});
// filter out un-supported implementations
list
=
list
.
filter
(
function
(
framework
)
{
return
excludedFrameworks
.
indexOf
(
framework
.
name
)
===
-
1
;
});
// if a specific framework has been named, just run this one
if
(
argv
.
framework
)
{
list
=
list
.
filter
(
function
(
framework
)
{
return
[].
concat
(
argv
.
framework
).
some
(
function
(
f
)
{
return
f
===
framework
.
name
;
});
});
if
(
list
.
length
===
0
)
{
console
.
log
(
'
You have either requested an unknown or an un-supported framework
'
);
console
.
log
(
'
You have either requested an unknown or an un-supported framework
'
);
}
}
}
// run the tests for each framework
// run the tests for each framework
...
...
tests/framework-path-lookup.js
0 → 100644
View file @
e128a635
var
fs
=
require
(
'
fs
'
);
var
frameworkNamePattern
=
/^
[
a-z-_
\d]
+$/
;
var
excludedFrameworks
=
[
// this implementation deviates from the specification to such an extent that they are
// not worth testing via a generic mechanism
'
gwt
'
,
// these implementations cannot be run offline, because they are hosted
'
firebase-angular
'
,
'
meteor
'
,
'
socketstream
'
,
// YUI is a special case here, it is not hosted, but fetches JS files dynamically
'
yui
'
,
// these frameworks take a long time to start-up, and there is no easy way to determine when they are ready
'
cujo
'
,
// sammyjs fails intermittently, it would appear that its state is sometimes updated asynchronously?
'
sammyjs
'
,
// elm-html batches UI updates with requestAnimationFrame which the tests
// don't wait for
'
elm
'
,
// these are examples that have been removed or are empty folders
'
emberjs_require
'
,
'
dermis
'
];
module
.
exports
=
function
(
names
)
{
// collect together the framework names from each of the subfolders
var
list
=
fs
.
readdirSync
(
'
../examples/
'
)
.
map
(
function
(
folderName
)
{
return
{
name
:
folderName
,
path
:
'
examples/
'
+
folderName
};
});
// apps that are not hosted at the root of their folder need to be handled explicitly
var
exceptions
=
[
{
name
:
'
chaplin-brunch
'
,
path
:
'
examples/chaplin-brunch/public
'
},
{
name
:
'
angular-dart
'
,
path
:
'
examples/angular-dart/web
'
},
{
name
:
'
duel
'
,
path
:
'
examples/duel/www
'
},
{
name
:
'
vanilladart
'
,
path
:
'
examples/vanilladart/build/web
'
},
{
name
:
'
canjs_require
'
,
path
:
'
examples/canjs_require/
'
},
{
name
:
'
troopjs
'
,
path
:
'
examples/troopjs_require/
'
},
{
name
:
'
thorax_lumbar
'
,
path
:
'
examples/thorax_lumbar/public
'
}
];
list
=
list
.
map
(
function
(
framework
)
{
var
exception
=
exceptions
.
filter
(
function
(
exFramework
)
{
return
exFramework
.
name
===
framework
.
name
;
});
return
exception
.
length
>
0
?
exception
[
0
]
:
framework
;
});
// filter out any folders that are not frameworks (.e.g hidden files)
list
=
list
.
filter
(
function
(
framework
)
{
return
frameworkNamePattern
.
test
(
framework
.
name
);
});
// filter out un-supported implementations
list
=
list
.
filter
(
function
(
framework
)
{
return
excludedFrameworks
.
indexOf
(
framework
.
name
)
===
-
1
;
});
return
list
.
filter
(
function
(
framework
)
{
return
[].
concat
(
names
).
some
(
function
(
f
)
{
return
f
===
framework
.
name
;
});
});
}
tests/memory.js
0 → 100644
View file @
e128a635
var
drool
=
require
(
'
drool
'
);
var
frameworkPathLookup
=
require
(
'
./framework-path-lookup
'
);
var
argv
=
require
(
'
optimist
'
).
default
(
'
laxMode
'
,
false
).
default
(
'
browser
'
,
'
chrome
'
).
argv
;
var
driverConfig
=
{
chromeOptions
:
'
no-sandbox
'
};
if
(
typeof
process
.
env
.
CHROME_PATH
!==
'
undefined
'
)
{
driverConfig
.
chromeBinaryPath
=
process
.
env
.
CHROME_PATH
;
}
var
driver
=
drool
.
start
(
driverConfig
);
var
list
=
frameworkPathLookup
(
argv
.
framework
);
function
idApp
()
{
return
driver
.
findElement
(
drool
.
webdriver
.
By
.
css
(
'
#todoapp
'
))
.
then
(
function
()
{
return
true
;
})
.
thenCatch
(
function
()
{
return
false
;
});
}
function
newTodoSelector
(
name
)
{
return
idApp
().
then
(
function
(
isId
)
{
if
(
isId
)
{
return
'
#new-todo
'
;
}
return
'
.new-todo
'
;
});
}
function
listSelector
(
name
)
{
return
idApp
().
then
(
function
(
isId
)
{
if
(
isId
)
{
return
'
#todo-list li
'
;
}
return
'
.todo-list li
'
;
});
}
list
.
forEach
(
function
(
framework
)
{
drool
.
flow
({
repeatCount
:
5
,
setup
:
function
()
{
driver
.
get
(
'
http://localhost:8000/
'
+
framework
.
path
+
'
/index.html
'
);
},
action
:
function
(
name
)
{
driver
.
wait
(
function
()
{
return
driver
.
findElement
(
drool
.
webdriver
.
By
.
css
(
newTodoSelector
(
name
)))
.
sendKeys
(
'
find magical goats
'
,
drool
.
webdriver
.
Key
.
ENTER
)
.
thenCatch
(
function
()
{
return
false
;
})
.
then
(
function
()
{
return
driver
.
findElement
(
drool
.
webdriver
.
By
.
css
(
listSelector
(
name
))).
isDisplayed
()
.
then
(
function
()
{
return
true
;
})
});
},
10000
);
driver
.
wait
(
function
()
{
return
driver
.
findElement
(
drool
.
webdriver
.
By
.
css
(
listSelector
(
name
))).
click
()
.
thenCatch
(
function
()
{
return
false
;
})
.
then
(
function
()
{
return
true
;
});
});
driver
.
findElement
(
drool
.
webdriver
.
By
.
css
(
'
.destroy
'
)).
click
();
}.
bind
(
null
,
framework
.
name
),
assert
:
function
(
after
,
initial
)
{
var
nodeIncrease
=
(
after
.
nodes
-
initial
.
nodes
);
var
listenerIncrease
=
(
after
.
jsEventListeners
-
initial
.
jsEventListeners
);
console
.
log
(
this
+
'
,
'
+
nodeIncrease
+
'
,
'
+
(
after
.
jsHeapSizeUsed
-
initial
.
jsHeapSizeUsed
)
+
'
,
'
+
listenerIncrease
);
//https://code.google.com/p/chromium/issues/detail?id=516153
if
(
nodeIncrease
>
5
)
{
throw
new
Error
(
'
Node Count leak detected!
'
);
}
if
(
listenerIncrease
>
0
)
{
throw
new
Error
(
'
Event Listener leak detected!
'
);
}
}.
bind
(
framework
.
name
)
},
driver
)
});
driver
.
quit
();
tests/package.json
View file @
e128a635
...
@@ -8,7 +8,8 @@
...
@@ -8,7 +8,8 @@
"mocha"
:
"*"
,
"mocha"
:
"*"
,
"mocha-known-issues-reporter"
:
"git+https://github.com/ColinEberhardt/mocha-known-issues-reporter.git#v0.0.0"
,
"mocha-known-issues-reporter"
:
"git+https://github.com/ColinEberhardt/mocha-known-issues-reporter.git#v0.0.0"
,
"optimist"
:
"^0.6.1"
,
"optimist"
:
"^0.6.1"
,
"selenium-webdriver"
:
"^2.46.1"
"selenium-webdriver"
:
"^2.46.1"
,
"drool"
:
"0.2.2"
},
},
"scripts"
:
{
"scripts"
:
{
"serve"
:
"http-server -p 8000 .."
,
"serve"
:
"http-server -p 8000 .."
,
...
...
tests/run.sh
View file @
e128a635
...
@@ -3,4 +3,5 @@
...
@@ -3,4 +3,5 @@
args
=
"
$@
"
args
=
"
$@
"
npm i
&&
\
npm i
&&
\
eval
"node memory.js
$args
"
&&
\
eval
"npm test --
$args
"
eval
"npm test --
$args
"
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