JSerのための ブラウザコードリーディング (テスト編)
by
Edward Fox
Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
JSerͷͨΊͷ ϒϥβίʔυϦʔσΟϯά ʢςετฤʣ EDWARD FOX @Meguro.es x Gotanda.js #1 2017/04/28
Slide 2
Slide 2 text
Edward Fox - Developer @ Repro Inc. - RoR, JavaScript, AWS - Vue.js, HTTP/2, WebAssembly
Slide 3
Slide 3 text
લճͷMeguro.esͰ ͜ΜͳΛͤͯ͞Β͍· ͨ͠
Slide 4
Slide 4 text
No content
Slide 5
Slide 5 text
ϒϥβͷΠϯεϖΫλʹ console.logͱೖྗͨ͠༰ ͕࣮ࡍʹදࣔ͞ΕΔ·Ͱ
Slide 6
Slide 6 text
ࠓճ͏ͪΐ͍ ࣮ફతͳΛ͠·͢
Slide 7
Slide 7 text
1. ຊ൪ڥͰΤϥʔ͕ى͖ͨ 2. ௐࠪͯ͠શવΘ͔ΒΜ 3. WebKitͷϦϙδτϦͰgrep 4. ςετίʔυʹώοτͨ͠
Slide 8
Slide 8 text
ςετίʔυΛಡΜͰ͍͘ͱ ৭ʑͱֶͼ͕͋ͬͨͷͰ ͍͔ͭ͘Λհ
Slide 9
Slide 9 text
WebKitͷιʔείʔυ֓؍
Slide 10
Slide 10 text
LayoutTests
Slide 11
Slide 11 text
1. DOM 2. Security 3. Performance #1 4. Performance #2
Slide 12
Slide 12 text
1. DOM
Slide 13
Slide 13 text
LayoutTests/dom/level2/core/ setAttributeNS10.html
Slide 14
Slide 14 text
ظ͢Δಈ࡞: > setAttributeʹෆਖ਼ͳจࣈ ྻΛ͢ͱ InvalidCharacterError͕ ্͕Δ͜ͱ
Slide 15
Slide 15 text
ϒϥβͰ։͘
Slide 16
Slide 16 text
SUCCESS!
Slide 17
Slide 17 text
2. Security
Slide 18
Slide 18 text
LayoutTests/security/ contentSecurityPolicy/image- with-blob-url-blocked-by-img- src-star.html
Slide 19
Slide 19 text
ظ͢Δಈ࡞: > ϖʔδʹ”image-src *”ͷ CSPϔομ͕ଘࡏ͢Δ߹ɺ blob URLΛ௨ͯ͡࡞͞Εͨ ը૾ͷಡΈࠐΈ͕ ϒϩοΫ͞ΕΔ͜ͱ
Slide 20
Slide 20 text
ϒϥβͰ։͘
Slide 21
Slide 21 text
PASS!
Slide 22
Slide 22 text
3. Performance #1
Slide 23
Slide 23 text
LayoutTests/perf/array-nested- loop.html
Slide 24
Slide 24 text
ظ͢Δಈ࡞: > ωετ͞Εͨྻͷ ܁Γฦ͠ॲཧͷ࣌ؒܭࢉྔ͕ O(n^2)Ͱ૿Ճ͢Δ͜ͱ
Slide 25
Slide 25 text
magnitude iterations 2 112352 4 52595 8 118454 16 75968 32 27994 64 7237 128 2277 256 699 512 186 1024 47 2048 12 4096 4
Slide 26
Slide 26 text
͡Ίͷํ͕҆ఆ ͠ͳ͍͕ɺ16Ҏ߱ظ ௨ΓͷύϑΥʔϚϯεྼԽ͕ ݟΒΕΔ
Slide 27
Slide 27 text
҆ఆ͠ͳ͍ཧ༝: ϒϥβͷJITίϯύΠϧʹ ͷ͔ͬΔ·Ͱͷϥάʁ ʢৄ͍͠ਓڭ͍͑ͯͩ͘͞ʣ
Slide 28
Slide 28 text
2. Performance #2
Slide 29
Slide 29 text
LayoutTests/perf/document- contains.html
Slide 30
Slide 30 text
ظ͢Δಈ࡞: > document.contains() ͷ ࣌ؒܭࢉྔ͕O(1)Ͱ͋Δ͜ͱ
Slide 31
Slide 31 text
magnitude iterations 2 70107 4 59787 8 95958 16 129782 32 128047 64 130236 128 140427 256 122163 512 115772 1024 130717 2048 117249 4096 138466
Slide 32
Slide 32 text
Γ͡Ίෆ҆ఆ͕ͩɺ 16͘Β͍͔ΒҰఆͷΛ อ͍ͬͯΔ
Slide 33
Slide 33 text
·ͱΊ
Slide 34
Slide 34 text
Undocumentedͳ༷ڍಈ Ͱ͋ͬͯɺϒϥβͷ ςετίʔυ ͪΌΜͱ͋ͬͨΓ͢Δ
Slide 35
Slide 35 text
=> ༷͚ͩͰͳ͘ɺ ࣮ʹͱͮ͘ڍಈ͕ ཧղͰ͖Δ
Slide 36
Slide 36 text
ϑΝΠϧ໊આ໌తͰɺ HTML/JSͰॻ͔Ε͍ͯΔͷͰ ࠶ݱ؆୯
Slide 37
Slide 37 text
=> ϒϥβͷςετίʔυ ΛಡΜͰ͍͘͜ͱͰɺ JavaScriptΛॻ͘ਓؒʹ ͱֶͬͯͼ͕͋Δ
Slide 38
Slide 38 text
͓·͚
Slide 39
Slide 39 text
WebKitϦϙδτϦશମͰ 27ສϑΝΠϧ͕͋ΔͷͰ grepͳͲ͕ΠνΠνਏ͍
Slide 40
Slide 40 text
- git status: 1-2 - git grep: 10ऑ
Slide 41
Slide 41 text
ରࡦ1: ιʔείʔυΛ෦తʹ μϯϩʔυ͢Δ
Slide 42
Slide 42 text
ରࡦ2: maxvodesͱ͍͏ ΧʔωϧύϥϝʔλͷΛ ্͛Δ
Slide 43
Slide 43 text
edwardkenfox.com/blog/ browser-test-code-for-jsers/