ALICE PlatformãšåŒã°ãã補åãäœæããŠããŸããè² è·ãã¹ãã®åé¡ãã©ã®ããã«è§£æ±ºãããã説æããŸãã
ã¢ãªã¹ã¯ããã«ã®ãžã©ã§ãã ç§ãã¡ã¯ã圌ãã圌ãã®å é¢ã«å¯ŸåŠããã®ãå©ãããã©ãããã©ãŒã ãæ§ç¯ããŠããŸãã ã³ã³ã·ã§ã«ãžã¥ãããã³ããªãã¬ãŒã¿ãŒãã¯ãªãŒããŒ-ãã±ãããå¿ èŠã§ãã äŸïŒã²ã¹ããé»è©±ãããã>éšå±ãæé€ããå¿ èŠããããšèšã>åŸæ¥å¡ããã±ãããäœæãã>æé€ããã人ãã¿ã¹ã¯ã®é 眮å ãç¥ã>å®è¡>ã¹ããŒã¿ã¹ãå€æŽããã
b2bãããã®ã§ãæ°åã¯ç®ç«ããªããããããŸãã-ããã1,000ããã«ã5,000 DAUã§ãã ã²ãŒã ã®å Žåãããã¯ããã»ã©å€ããããŸããããç§ãã¡ã«ãšã£ãŠã¯éåžžã«ã¯ãŒã«ã§ããæ倧8ã€ã®prod-serverãããããããã®5,000人ã®ã¢ã¯ãã£ããŠãŒã¶ãŒã«ã»ãšãã©å¯ŸåŠã§ããªãããã§ãã å éšã§ã¯ãããã«ç°ãªãããšãçºçãããããããŒã¿ããŒã¹ããã©ã³ã¶ã¯ã·ã§ã³ãªã©ã®æãçºçããŸãã
æãéèŠãªããšïŒéå»1幎éã§2åã«æé·ããçŸåš50人ã®å°åã«ãšã³ãžãã¢ãªã³ã°ããŒã ãããã2019幎ã«ã¯ãŠãŒã¶ãŒããŒã¹ã2åã«ããäºå®ã§ãã ãããŠãããã¯ç§ãã¡ãçŽé¢ããäž»ãªèª²é¡ã§ãã
人çããã®äŸã éææ¥ã®å€ãé±60æéã®å€åã®åŸã23ïŒ00ã«ç§ã¯æåŸã®é»è©±ãçµããããã«ãã¬ãŒã³ããŒã·ã§ã³ãå®äºããé»è»ã«é£ã³ä¹ã£ãŠããã«æ¥ãŸããã çŽ5ååããã¬ãŒã³ããŒã·ã§ã³ãå°ãããçŽããŸããã ç§ãã¡ã¯ã¹ã¿ãŒãã¢ããã§ãããã¯ãŒã«ã ããã§ãã ç§ãé転ããŠããéãæè¡ããŒã ã®äžéšïŒæ¬çªç°å¢ã§ã¯ç«äºãšåŒã³ãŸãïŒãã·ã¹ãã ãããŠã³ããªãããšã確èªããããšããŸããããåæã«ãŠãŒã¶ãŒã¯ããã«æ°ã¥ããŸããã§ããã 圌ãã¯æåããç§ãã¡ã¯æãããŸããã
ã芧ã®ãšãããä»ã®ãšããå€ã¯ããŸãããç ããŠããŸããã ç§ãã¡ã¯ã€ã³ãã©ã厩å£ããããšã確信ããŠããŸãã ç§ãã¡ã¯çå®ã«çŽé¢ãããããç解ããŠããŸãã äžã€ã®è³ªåïŒãã€ïŒ ããããè² è·ãã¹ããæãã®éµã§ããããšãç解ããæ¹æ³ã§ãã ããã¯ç§ãã¡ãæ°ã«ããå¿ èŠããããã®ã§ãã
ç§ãã¡ã®ç®æšã¯äœã§ããã ãŸããã·ã¹ãã ã®å®¹éãšããã©ãŒãã³ã¹ãçŸåšã®ãŠãŒã¶ãŒã«ãšã£ãŠã©ãã ãããŸãæ©èœããããæ£ç¢ºã«ç解ããå¿ èŠããããŸãã ãããŠãäœããæ©èœããŠããªããéåžžã«é ããšããäºå®ã®ããã«ããŠãŒã¶ãŒãç§ãã¡ãšã®å¥çŽãç Žãåã«ãããèµ·ããã¯ãã§ãïŒããã¯150ã®ããã«ãšããããã®ãéã®ã¯ã©ã€ã¢ã³ãã«ãªãå¯èœæ§ããããŸãïŒã ããã«ãå¶æ¥éšéã«ã¯æ¬¡ã®èšç»ããããŸãïŒæ¥å¹Žã«2åã®æé·ã ãããŠãäž»ãªç«¶åä»ç€Ÿãè³Œå ¥ãããŠãŒã¶ãŒãèªåèªèº«ã«ç§»è¡ããã®ã§ãã
ãããŠãããããã¹ãŠãèããããããšãç¥ã£ãŠããå¿ èŠããããŸãã ãããã®ãŠãŒã¶ãŒãæ¥ãŠãã¹ãŠãèœã¡ãåã«ãäºåã«ç¥ã£ãŠãããŠãã ããã
ãªãªãŒã¹ãè¡ããŸãã æ¯é±ã æææ¥ã«ã ãã¡ããããã¹ãŠã®ãªãªãŒã¹ãæ©èœãã©ããã§ã®ã¡ã³ããã³ã¹ãã©ããã§ã®ãã°ä¿®æ£ãæ¡åŒµããããã§ã¯ãããŸãããããŠãŒã¶ãŒãããã«æ°ä»ããããŠãŒã¶ãŒã®äœéšãæªåããªãããšãç解ããå¿ èŠããããŸãã
ããããç§ãã¡ã¯åªããéçºè ãšããŠãæ ãè ã§ãããä»äºãããã®ã¯å¥œãã§ã¯ãããŸããã ãã®ããã圌ãã¯ã³ãã¥ããã£ãšGoogleã«ãè² è·ãã¹ãã«ã©ã®ãããªãµãŒãã¹/ãœãªã¥ãŒã·ã§ã³ãããããå°ããŸããã ãããããããŸããã Apache Benchã®ããã«ãURLå ã®100ã¹ã¬ããã§ãµã€ããåçŽã«ããã¯ãããããªåçŽãªãã®ãããã€ããããŸãã ãã·ã³ã¬ã³ãæèŒããèã®éªæªã§å¥åŠãªããŒãžã§ã³ãããããã¹ãŠãåãã§ãããã¢ããªã±ãŒã·ã§ã³ãé£ã°ããŠé 眮ããã€ã³ã¹ã¿ã³ã¹ãéå§ããŸãã JMeterããããŸããããã§ã¯ãããã€ãã®ã¹ã¯ãªãããäœæããã¯ã©ãŠãã§å®è¡ã§ããŸãã
ãã¹ãŠãããŸãããããã«æããŸãããèããåŸãç§ãã¡ã¯æ¬åœã«åããããã€ãã®åé¡ãæåã«è§£æ±ºããªããã°ãªããªãããšã«æ°ä»ããŸããã
æåã«ãå šè² è·ãã·ãã¥ã¬ãŒãããå®éã®ã·ããªãªãäœæããå¿ èŠããããŸãã äžéšã®ã·ã¹ãã ã§ã¯ãã©ã³ãã ããŒã¿ã䜿çšããŠã©ã³ãã APIåŒã³åºããçæããã ãã§ååã§ãã ç§ãã¡ã®å Žåããããã¯é·ããŠãŒã¶ãŒã·ããªãªã§ããé»è©±ãåä¿¡ããç»é¢ãéãããã¹ãŠã®ããŒã¿ïŒã ããæããã®ãåŒã³åºãããïŒãä¿åããŸããã 次ã«ããªã¯ãšã¹ããå®è¡ããå¥ã®äººã®ã¢ãã€ã«ã¢ããªã±ãŒã·ã§ã³ã«è¡šç€ºãããŸãã æãç°¡åãªã¿ã¹ã¯ã§ã¯ãããŸããã
ãŸããæ¯é±ãªãªãŒã¹ããŠããŸãã æ©èœãæŽæ°ãããã¹ã¯ãªããã¯æ¬åœã«é¢é£ããŠããå¿ èŠããããŸãã æåã«ããããäœæãã次ã«ãããããµããŒãããå¿ èŠããããŸãã
ããããããã¯æ倧ã®åé¡ã§ã¯ãããŸããã§ããã flood.ioãäŸã«åããŸãã ã¯ãŒã«ãªããŒã«ã§ããSeleniumãå®è¡ã§ããŸããããã¯ãChromeãèµ·åãããšãã«å¶åŸ¡ã§ããäœããã®ã¹ã¯ãªãããå®è¡ããŸãã ãã®äžã§JMeterã¹ã¯ãªãããå®è¡ã§ããŸãã ããããSeleniumãJMeterã¹ã¯ãªããå ã§å®è¡ãããå Žåããã¹ãŠãçªç¶ã°ãã°ãã«ãªããŸããããã¯ãSeleniumãçµã¿ç«ãŠã人ãå€ãã®ã¢ãŒããã¯ãã£äžã®æ±ºå®ãäžããããã§ãã ãŸãã¯ãããšãã°ãäžéšã®ãµãŒãã¹ã¯JUnitãå®è¡ã§ããŸããããã¯åçŽã§ç°¡åã§ããããããã®ãµãŒãã¹ã®1ã€ã¯ç¬èªã®JUnitãäœæããããã€ãã®ããšãåã«ç¡èŠããŸãã
åããŒã«ã¯ç¬èªã®æ¹æ³ã§çæãèŠæ±ãããããè² è·çæã®åé¡ã¯ç·æ¥ã§ãã ãããŠãã·ããªãªãé©åã§ããããšã確èªã§ãããšããŠããçåãçããŸãã2ã4åå®è¡ããæ¹æ³ã§ããã ã©ãããïŒå®è¡ãããã¹ãŠãæ£åžžã§ãã ãããããããŸããã ãããã®ãªã¯ãšã¹ãã«ã¯ããããçš®é¡ã®IDããããŸããäœããäœæããæ°ããIDãååŸããå€ãIDãå€æŽããIDã«ãã£ãŠãšã³ãã£ãã£ãããŒããããã®ãã£ãŒã«ããå¥ã®ãã£ãŒã«ãã«å€æŽããŸãã ãŸããåããšã³ãã£ãã£ã10åããŒããã10åã®ãã¹ãã¯ããŸãé¢çœããããŸããã 10åã¯ç°ãªããšã³ãã£ãã£ãããŒããããã®ããŒããæ£ããã¹ã±ãŒãªã³ã°ããå¿ èŠãããããã§ãã
è² è·ãã¹ãã®åé¡ã解決ããŠãã¢ããªã±ãŒã·ã§ã³ãèãããŠãŒã¶ãŒæ°ãæ£ç¢ºã«ææ¡ããèšç»ãå¶æ¥éšéã®èšç»ãšäžèŽããŠããããšã確èªããŸãã åžå Žã«åºãŠãããœãªã¥ãŒã·ã§ã³ãåæãããã¹ã¿ãšã¹ãã£ãã¯ã®ã€ã³ãã³ããªãäœæããŸããã
æ¯é±ãªãªãŒã¹ãè¡ãã®ã§ãåœç¶ãçµ±åããã®ä»ã®ãã¹ããèªååããŸããã ããã«ã¯ãã¥ãŠãªã䜿çšããŸãã ããã¯ãè¡åé§ååéçºã®ããã®BDDãã¬ãŒã ã¯ãŒã¯ã§ãã ã€ãŸã æé ã§æ§æãããããã€ãã®ã·ããªãªãå°ããŸãã
ã€ã³ãã©ã¹ãã©ã¯ãã£ã«ãããçµ±åããã³æ©èœãã¹ãã2ã€ã®ã¢ãŒãã§å®è¡ã§ããŸãããããã¯ãšã³ããããã¯ãããAPIãäœåãããããŸãã¯å®éã«Seleniumãä»ããŠChromeãå®è¡ããŠç®¡çãããšãããã®ã§ãã
NewRelicã倧奜ãã§ãã ãµãŒããŒãäž»ãªææšãåçŽã«ç£èŠã§ããŸãã JVMã«çµ±åãããã³ã³ãããŒã©ãŒããã³ãšã³ããã€ã³ãAPIãžã®ãã¹ãŠã®åŒã³åºããã€ã³ã¿ãŒã»ããããŸãã ãŸãããã©ãŠã¶ãœãªã¥ãŒã·ã§ã³ããããã»ãšãã©ã®æ©èœãåããŠããããããã©ãŠã¶ã§äœããå®è¡ããäœããã®ã¡ããªãã¯ã¹ãæäŸããŸãã
ãããã£ãŠããã¹ãŠããŸãšããå¿ èŠããããŸãã äž»ãªã·ããªãªã¯ãã§ã«èªååãããŠããŸãã ã¹ã¯ãªããïŒBDDã«äŒŒãŠããããïŒã¯å®éã®ãŠãŒã¶ãŒãã·ãã¥ã¬ãŒãããè² è·ã¯å®éã®æ¬çªã«äŒŒãŠããŸãã åæã«ãã¹ã±ãŒãªã³ã°ããããšãã§ããŸãã ããã¯ãªãªãŒã¹ããã»ã¹ã®äžéšã§ãããããåžžã«ææ°ã®ç¶æ ã«ä¿ãããŸãã
次ã«ãçŸåšåžè²©ãããŠããããŒã«ãåãäžããŸãã ãããã¯åãããªããã£ãã§åäœããŸãïŒhttpãhttpã®APIåŒã³åºããJSONãJUnitãããã ãã§ãã ããããCucumberã§ãã¹ããå®è¡ãããšããã«ãåãããšãè¡ããåãããšãå®è¡ããŸãããäœãæ©èœããŸããã ç§ãã¡ã¯ãã®ã¿ã¹ã¯ã«ã©ã察åŠããããèãå§ããŸããã
äœè«ã§ãããBDDã¯ã²ãŒã éçºã§ã¯ããŸãäžè¬çãªçšèªã§ã¯ãªãããããšã³ã¿ãŒãã©ã€ãºãœãªã¥ãŒã·ã§ã³åãã§ãã
ãã¹ãŠã®ã·ããªãªã¯ãå®éã«ããçš®ã®åäœã説æããŠããŸãã ã·ããªãªã®èšè¿°åœ¢åŒã¯éåžžã«åçŽã§ããGherkinãšåŒã°ããBDDã®èŠ³ç¹ãããGivenãWhenãThenã®å Žåã§ãã ãã¥ãŠãªã¯ãã¢ãããŒã·ã§ã³ãšå±æ§ã䜿çšããŠããããJavaã³ãŒãã«ãããã³ã°ããŸãã 圌ã¯ã·ããªãªã§åœŒãèŠãŠããããšãããŸããããªãã¯ãã®äººã«ãªã³ãŽãäžããå¿ èŠããããŸãããããå®è£ ããæ¹æ³ãèŠã€ããŸãããã
次ã«ãæ©èœããããã®ãããªã³ã³ã»ãããå°å ¥ããŸããã ããã¯ã¢ããªã±ãŒã·ã§ã³ã®ç¹å®ã®ã¯ã©ã€ã¢ã³ãã§ããããŠãŒã¶ãŒã®ãã°ã€ã³ããã°ã¢ãŠãããã±ããã®äœæããã±ããã®ãªã¹ãã®è¡šç€ºãªã©ã®ã¡ãœããããããŸãã ãŸããã¢ãã€ã«ã¢ããªã±ãŒã·ã§ã³ãWebã¢ããªã±ãŒã·ã§ã³ãããã³APIåŒã³åºããè¡ã3ã€ã®ã¢ãŒãã§åäœããŸãã
ç°¡åã«èšãã°ãã¹ã©ã€ãäžã®åããã®ã§ãã æ©èœãã¡ã€ã«ã¯ã¹ã¯ãªããã«åå²ãããŠãããæé ããããããã¯ãã¹ãŠè±èªã§æžãããŠããŸãã
次ã«ãJavaã³ãŒãã§ããCucumberãç»å Žãããããã®ã¹ã¯ãªãããå®éã«å®è¡ãããŠããã³ãŒãã«ãããããŸãã
ãã®ã³ãŒãã¯ã¢ããªã±ãŒã·ã§ã³ã䜿çšããŸãã
ãããŠãéžæããå 容ã«å¿ããŠãSelenium Chromeãä»ããŠALICEã¢ããªã±ãŒã·ã§ã³ã«ç§»åããŸãã
ãŸãã¯ãHTTP APIãä»ããåãããšã
ãããŠãïŒã¢ãªã¥ãŒã«ã¬ããŒãã®Yandexã®ãããã§ïŒããã¯ãã¹ãŠãç§ãã¡ã«çŸãã瀺ãããŠããŸã-ã©ããããã®æéãã©ã®ãã¹ããå転ããã©ã®ã¹ãããã§ãäœããããŸããããªãã£ããã¹ã¯ãªãŒã³ã·ã§ãããé©çšããŸãã
ããã«ãç§ãã¡ããã§ã«æã£ãŠãããã®ã®ç°¡åãªèŠçŽããããŸãã
ããããè² è·ãã¹ããæ§ç¯ããæ¹æ³ã¯ïŒ Cucumber Suiteãå®è¡ããJenkinsãããŸããã ãããã¯ç§ãã¡ã®ãã¹ãã§ãããALICEã«è¡ããŸããã äž»ãªåé¡ã¯äœã§ãããïŒ Jenkinsã¯ãã¹ããããŒã«ã«ã§å®è¡ããŸã;æ°žä¹ ã«æ¡åŒµããããšã¯ã§ããŸããã ã¯ããAmazonã§ãã¹ããããŠããŸããã¯ã©ãŠãã§ãç¹å€§ã®ãã·ã³ãèŠæ±ã§ããŸãã ãšã«ãããããæç¹ã§ãå°ãªããšããããã¯ãŒã¯ã«ãããããŸãã äœããã®æ¹æ³ã§ãã®è² è·ãããŒãããå¿ èŠããããŸãã ã¢ããŸã³ã®ãããã§ã圌ã¯ç§ãã¡ã®ããã«èããŸããã Cucumber SuiteãDockerã³ã³ãããŒã«ããã¯ããAWSãµãŒãã¹ïŒFargateãšåŒã°ããïŒã䜿çšããŠããããããèµ·åããŠãã ããããšèšãããšãã§ããŸãã åé¡ã¯è§£æ±ºãããã§ã«ã¯ã©ãŠãã§ãã¹ããå®è¡ã§ããŸãã
次ã«ãã¯ã©ãŠãã«ããã®ã§ã5-10-20 Cucumber Suiteãå®è¡ããŸãã ãã ãã埮åŠãªéãããããŸãããã¹ãŠã®æ©èœãã¹ããå®è¡ãããã³ã«ã¬ããŒããçæãããŸãã 400ã®ãã¹ããå®è¡ãã400ã®ã¬ããŒããçæãããŸããã
ãªãŒãã³ãœãŒã¹ã®Yandexã®ã¹ã¿ããã®ãããã§ãããã¥ã¡ã³ããšãœãŒã¹ã³ãŒããèªã¿ã400ã®ã¬ããŒããã¹ãŠã1ã€ã«ãŸãšããæ¹æ³ãããããšã«æ°ä»ããŸããã ããŒã¿ããããã«ä¿®æ£ããããã€ãã®æ¡åŒµæ©èœãäœæããŸãããããã¹ãŠããŸããããŸããã
Jenkinsãããã200åã®ã€ã³ã¹ã¿ã³ã¹ãæäŸããŠãã ããããšèšããŸãã ç¹å®ã®ãªãŒã±ã¹ãã¬ãŒã·ã§ã³ã¹ã¯ãªãããAmazonã«éä¿¡ãããã400ã®ã³ã³ãããŒãèµ·åããããšèšããŸãã ããããã«çµ±åãã¹ããå«ãŸããŠãããã¬ããŒããçæããŸããã¬ããŒãã¯ã¢ã°ãªã²ãŒã¿ãŒãä»ããŠ1ããŒã¹ã«åéããããžã§ã³ãã³ã¹ã«çœ®ããããžã§ãã«é©çšãããéåžžã«æ©èœããŸãã
ãããã
å€ãã®äººããã¹ã¿ãŒããå¥åŠãªããšãåãåã£ããšæããŸãããã²ãŒã ããã¬ã€ãã10åãžã£ã³ãããæ®åœ±ãæ¿ããæŒããŠã誀ã£ãŠã·ã£ããããŠã³ãã¿ã³ãæŒãã-ãã£ã©ã¯ã¿ãŒãç¹æ» ãå§ãã空äžã§ããªãŒãºããã³ã³ãã¥ãŒã¿ãŒã®é»æºãåãããããã«å¯ŸåŠãããã ããªãã¯ãŸã 人ã«åæããããªããç¥ã£ãŠãããããã¯è€è£œããããšã¯äžå¯èœã ãšèšãããšãã§ããŸãã ããããéã®ãªããã·ã³ãããããã¹ãŠãéåžžã«è¿ éã«å®è¡ããããŒã¿ãããŒããããªãã£ãå Žæãã¬ã³ããªã³ã°ãè¿ éã«è¡ãããªãã£ãå Žæããã¿ã³ãæŒããããšããŸãããããã¿ã³ããŸã ãªãããŸãã¯ãµãŒããŒãããŸã ããŠã³ããŒããããŠããªãããŒã¿ã䜿çšããŠããã ãã¹ãŠã厩å£ãããã¹ãã«æ¬ é¥ããããŸãã ïŒããã«éäžãããã®ã§ããïŒChromeãå®è¡ããJavaã³ãŒãããããŸããChromeã¯ãã©ãããŒãä»ããŠå¥ã®Javaã«æ¥ç¶ããäœããå®è¡ããããã§ãè¶ é«éã§åäœããŸãã
ããŠãããããçããæãããªåé¡ïŒ5000人ã®ãŠãŒã¶ãŒããããæ©èœãã¹ãã®ã€ã³ã¹ã¿ã³ã¹ã100ã®ã¿èµ·åããåãè² è·ãäœæããŸããã æ¥æã«ã¯6,000人ã®ãŠãŒã¶ãŒãäºå®ããŠãããããããã¯ãŸãã«æãã§ãããã®ã§ã¯ãããŸããã ãã®ãããªè² è·ãç解ããããšãéå§ããã¹ã¬ããã®æ°ãç解ããããšã¯å°é£ã§ãã
ããŠãã·ã¹ãã ã人éåããŸãããã ãŠãŒã¶ãŒã€ã³ã¿ãŒãã§ã€ã¹ã¯æ¬¡ã®ããã«ãªããŸãã
誰ããé»è©±ããããŠããŠãã³ã³ã·ã§ã«ãžã¥ã¯ãæ°ãããã±ãããäœæããããã¿ã³ãæŒããããšæã£ãŠããŸãããŠã£ã³ããŠã衚瀺ããã圌ã¯ãã¹ãŠã®ãã£ãŒã«ãã«å ¥åããå¿ èŠããããŸãã
ããããããã¯ããã«ã¯èµ·ãããŸããã ããŠã¹ã«å°éãããŸã§ãå ¥åãéå§ãããŸã§ãäœããéžæãããŸã§ã[ä¿å]ãã¯ãªãã¯ãããŸã§ã®å®éã®äººç©ã ããã§ã¯ãã¹ããé ãããŸãããã
ãã¥ãŒãã³ã¢ãŒããšåŒã³ãŸãã ã¹ããããã©ãã ãç¶ããã枬å®ããéãããå Žåã¯å°ããã¹ãªãŒããããå¿ èŠããããŸãã åæã«ãååãšããŠãã®ã¹ããããã©ããããããã£ããã枬å®ã§ããŸã-5åã§ããã°ããããããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãå£ããŠããŸãã
ããªãã®æ°ã®ãã¹ãããã£ãã®ã§ããã®ããšã§ãããããæžãçŽãããšã¯ããŸããã§ããã 圌ãã¯AspectJãååŸããã³ãŒãã«è¿œå ããããã«5è¡ã®ã³ãŒããè¿œå ããŸããã
çããã¢ã
ããã¯ã¿ã€ã ã©ã€ã³ã®å®è¡ã§ãã ã°ãªãŒã³ãã¹ãã¯è¯ããã©ãããæªãã ã¢ãªã¥ãŒã«ã¯ãå転ããå Žæã®è©³çŽ°ã衚瀺ããŸãã
ãããŠãããã«å€ãã®ã€ã³ã¹ã¿ã³ã¹ããã£ãããšã瀺ãã¿ã€ã ã©ã€ã³ããããŸãã 圌ãã¯ãã¹ããè¡ããã©ããã§èœã¡ãŸããã
ãã®ã·ã¹ãã ã¯æ¬åœã«æ©èœããŠããŸããå é±ãæŠéçç£ã«é¢ããæåã®ãã¹ããè¡ããŸããã
次ã®ã¹ãããã«ã€ããŠã¯ãã©ã®ããã«æ¹åã§ãããšä¿¡ããŠããŸãã
æãéèŠãªããšã¯ã人ã ã«ã¯ãŒã«ãªãŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãæäŸããããšã§ãã ã¢ã€ãã¢ã¯ãã¢ããªã±ãŒã·ã§ã³ã«å€§ããªè² è·ããããããšãã§ãããã¹ãŠãåçŽã§ãããã®ããã§ã-ãµãŒããŒãžã®åãªã¯ãšã¹ãã®ããã©ãŒãã³ã¹ããé«éã§å¿çãç¶ããããããã©ãŒãã³ã¹ã®äœäžãå§ãŸããïŒãµãŒããŒã¯çä¿¡ãªã¯ãšã¹ãã®åŠçãããé ãéå§ããŸããïŒ ãããããããŸããã å®éã«ã¯ãã¯ã©ã€ã¢ã³ã/ã¢ããªã±ãŒã·ã§ã³ã¯äžåºŠã«è€æ°ã®ãªã¯ãšã¹ãããµãŒããŒã«äžåºŠã«æããããšãã§ããŸãã ãããŠããããããã¹ãŠåŠçããããŸã§åŸ ã¡ãŸãã ãããŠããªã¯ãšã¹ãã®ãããããæé·ã§ã5ç§éæ©èœãã5ç§éæ©èœãç¶ããå Žåãä»ã®ãã¹ãŠã®ãŠãŒã¶ãŒãã©ã®ããã«åäœãããã¯ãŸã£ããæ°ã«ããŸãã-é«éãŸãã¯4ç§ãŸã§æžéããŸãã çµå±ã®ãšãããç§ãã¡ã¯æé·ã®5ç§ãåŸ ã¡ãŸãã ãŸãã¯ããã±ãããäœæãããšããã¹ãŠã1ããªç§ã§æ©èœããŸããããå éšã€ã³ããã¯ã¹ãã£ãã·ã¥ã®ããã«ãã±ãããã·ã¹ãã ã«è¡šç€ºãããã®ãé ãããŸããã éåžžã®ã¢ãããŒãã§ã¯ãã®åé¡ã解決ã§ããªãããããã¹ãŠã®ã·ããªãªã枬å®ãããã±ããäœæã¹ã¯ãªãããå®éã«ã©ãã ãæªåãããã確èªããããšæããŸãã
ãªããªã 䜿çšæ³ã«åºã¥ãããã¹ãŠã®ã·ããªãªããããåä»ã§1人ãš10人ã®ã¯ãªãŒããŒãå®è¡ããããšã§æš¡å£ã§ããŸãã ãã®åŸã20ãŸãã¯30ã®ã¯ãªãŒããŒã ãããã人ã ã®æ£é¢ã¯ãŸã åãã§ãã ã€ãŸã å®éã®è² è·ã«éåžžã«è¿ããåäœãã¿ãŒã³ã«ãã£ãŠå®éã®è² è·ãçæã§ããŸãã
ãŸããè€æ°å°åã®ãã¹ãã ç§ãã¡ã®ã·ã¹ãã ã¯äžçäžã§äœ¿çšãããŠããŸãïŒãã¹ãŠãã¢ã¡ãªã«ã§ãã¹ããããŠããŸããïŒããããã£ãŠããã·ã¢ãšã¢ã¡ãªã«ã®äž¡æ¹ããè² è·ãçæããã©ã¡ããããéãæžéãå§ãããã確èªã§ããŸãã
èŽè¡ããã®è³ªå
-倧éã®ããžãã¯ãæžãããšãäœåãªããããäœããå°ãå€æŽããããšãæ©èœãã¹ãã§å€ãã®ããšãå£ããŸãã ãã¹ãããµããŒãããããã«ã¯ãéçºãããããã»ãšãã©æéãããããŸããïŒ
ãã¯ããã§ããããã ããã¯BDDã§ãããããã¯å®å šã«æ©èœçãªãã¹ãã§ã¯ãªããçµ±åãã¹ãã«è¿ããã®ã§ãã ãããŠãã©ã®ãããªå€æŽãè¡ã£ãŠããã·ããªãªã¯å€ãããŸããã ãã¿ã³ãæŒããšããŠã£ã³ããŠã衚瀺ãããŸãããã®äžã«ããªã¯ãšã¹ããåãåã£ãéšå±ã®çªå·ã人ã®ååãããŒãã«ãäºçŽããæ¥ä»ãå ¥åããŸãã ã¬ã€ã¢ãŠããå€æŽããããã£ãŒã«ããéã«ãªããããã¯ãšã³ãã§äœããçºçããå Žåããã¹ãã¯ä¿åãããŸããéåžžã«é«ãã¬ãã«ã«ããããããã©ãŠã¶ãŒã®ãã¿ã³ãæŒããŸãã ãã®ãããå€æ°ã®å€æŽããä¿è·ãããŠããŸãã ãã¹ãŠãå£ããå ŽåããããŸãã ãããã£ãŠããªãªãŒã¹æé ã§ã¯ãæ°ããæ©èœãäœæãã人ãã¡-äœããå£ããŠããããšã確èªããŠä¿®æ£ãã責任ããããŸãã ãããããããŸã§ã®ãšããããã®ãããªåé¡ã¯å€æ°ãããŸããã
-ãããŠã1ã€ã®å€æŽåŸã«ãã¹ãŠã®ãã¹ããèµ€ããªãç¶æ³ã¯ãããŸããã§ããã
-ããã§ã¯ãªãã£ãã çè«çã«ã¯ãã¹ã¯ãªããã«ãã¿ã³ããªãããã±ããæ å ±ãå ¥åããããã®ãŠã£ã³ããŠãéãä»ã®æ¹æ³ãããå Žåã«çºçããå¯èœæ§ããããŸãã ãã ããåã«ç€ºããããã«ãã·ããªãªã¯ãã¹ãŠã¹ãããã§æ§æãããŠããŸãã ã¹ãããã¯ãã¹ãŠãå€ããåããã¿ã³ãã¯ãªãã¯ãã100åã®ã¹ã¯ãªãããããå Žåãã¹ãããã¯ãŸã 1ã€ã§ãã ãããŠããã®ç¹å®ã®ã¹ãããã®ããã«ãã¹ãŠãããŠã³ããå Žåããããä¿®æ£ãæžãæãããã¹ãŠã®ãã¹ããããã«ç·è²ã«å€ãããŸãã
ãã€ãŠãå¶ç¶äœããå£ãããšããããã¯ç§ãã¡ã«èµ·ãããŸããã ç·ã®40ïŒ ããæ®ã£ãŠããŸããã§ãããããã以åã¯99ïŒ ã§ããã ããã¯å°ããªå€åã§ããã 1ã¹ãããïŒã³ãŒãã®è¡ïŒãä¿®æ£ãããã¹ãŠãåã³ç·è²ã«ãªããŸããã
-çµ±åãã¹ãã¯ãããŸããããå®å šã«æ©èœããããã§ã¯ãããŸããã ãããã«ãããããã¯äœããã®ãã¿ã³ãæŒãããã°ã©ãã£ã«ã«ã€ã³ã¿ãŒãã§ã€ã¹ã§ãããå€éšã·ã§ã«ãšã®çžäºäœçšãç¹ã«è¡ãããŸãã ãã®åœ¢åŒã®ãã¹ããããããšãç解ããŠããŸããåæã«å€ãã®ã¹ã¬ãããéå§ããã ãã§ãã ãããŠããªãæšæºã·ã§ã«ïŒJMeterãGatlingã«ãã£ãŠçæããããªã¯ãšã¹ããæºãããŠããªãã®ã§ããïŒJMeterãGatlingããããã¯å€éšã·ã§ã«ãšã¯äžåããåããããåã«ãªã¯ãšã¹ãããµãŒããŒã«æ³šããŸããïŒ
-ãã¹ãŠãéåžžã«ç°¡åã§ãã ã¢ããªã±ãŒã·ã§ã³ã®ã¢ãŒããã¯ãã£ã¯äœã§ããïŒ ããã¯ãšã³ããšããã³ããšã³ãããããŸãã ããã³ããšã³ãã¯ãŠã§ãã§ãã ã¢ãã€ã«ã¢ããªã±ãŒã·ã§ã³ããããŸãã ãã±ãããäœæãããšãããã³ããšã³ãã¯ãããšãã°ã€ãã³ããµãŒããŒã«ãæ¥ç¶ãããŸãã ããã¯ãšã³ãã§ãã±ãããäœæããåãããã«ã«åº§ã£ãŠãããã¹ãŠã®äººãåãããã«ã®ãã±ãããèŠããšãã€ãã³ããµãŒããŒããå°çããŸããã¿ããªãæŽæ°ãããããã§ããŒã¿ãå€æŽãããŸãã ãããŠããã¹ãŠããŸãšããããã«ãåäžã®ãã€ã³ãããããŸã-ãããã¯ã©ã€ã¢ã³ãã§ãã å€æ°ã®ããŸããŸãªã³ã³ããŒãã³ãã«æ¥ç¶ããããã¯ãšã³ãã§ãã±ãããäœæããããã«æã§ããã°ã©ã ããŠãããã€ãã³ããµãŒããŒã«æ¥ç¶ããŠç»é²ããããããã®ã€ãã³ããåŸ ã¡ãŸãã , , .
â ? . .
â , , . , Chrome . , , , , , . Chrome â , , . , , Java- . , .
â , , . . , : - ?
â , - . , , , . , , . YouTube , . , . , .
â . - Selenium Grid ? - .
â Cucumber': JAR, JAR Docker image Fargate' , image . flood.io grid Selenium , .
â ? , Chrome, . Internet Explorer 4 ( - ), ? - Android -.
â , enterprise. enterprise , requirements. â , , web view. Android web view , .
â , , Load-? ?
â .
Environment . . , Load, . 4- , , aliceapp.com. Load- , . , 504, , MySQL ElasticSearch.
â ( ), , ? .
â Load- , . ã€ãŸã .
â , ?
â , . , , , .
â , , .. html API?
â Selenium DOM- : , , key down , â . .
â ? , ?
â . , . QC, , QC. Smoke- -. « -, ». â , , , .
Pixonic DevGAMM Talksãšã®ãããªãè¬æŒ
- Consulã䜿çšããã¹ããŒããã«ãµãŒãã¹ã®ã¹ã±ãŒãªã³ã° ïŒIvan BubnovãDevOps at BIT.GAMESïŒ;
- CICDïŒããŠã³ã¿ã€ã ãªãã®åæ£ã¯ã©ã¹ã¿ãŒã·ã¹ãã ãžã®ã·ãŒã ã¬ã¹ãªå±é ïŒEgor PanovãPixonicã·ã¹ãã 管çè ïŒ;
- Quake Championsã²ãŒã ã®ããã¯ãšã³ããã©ãããã©ãŒã ã§ã¢ã¯ã¿ãŒã¢ãã«ã䜿çšããç·Žç¿ ïŒRoman Rogozinãããã¯ãšã³ãéçºè Sabre InteractiveïŒã
- Tacticoolã¢ãã€ã«ãªã³ã©ã€ã³ã·ã¥ãŒã¿ãŒã¡ã¿ãµãŒããŒã¢ãŒããã¯ã㣠ïŒPavel PlattoãPanzerDogã®ãªãŒããœãããŠã§ã¢ãšã³ãžãã¢ïŒ;
- ECSãCïŒãžã§ãã·ã¹ãã ãSRPãã¢ãŒããã¯ãã£ãžã®ã¢ãããŒããã©ã®ããã«å€ããã ïŒValentin SimonovãUnityã®ãã£ãŒã«ããšã³ãžãã¢ïŒ;
- éçºã«ãããKISSåå ïŒKonstantin Gladyshevã1C Game Studiosã®ãªãŒãã²ãŒã ããã°ã©ããŒïŒ;
- ã¯ã©ã€ã¢ã³ããšãµãŒããŒã®äžè¬çãªã²ãŒã ããžã㯠ïŒPixonicã®å¯æè¡è²¬ä»»è ãAnton GrigorievïŒã