====== 워드프레스 플러그인 유닛 테스팅 ====== ===== 설치 과정 ==== ==== PHPUnit ==== Ubuntu 패키지로 PHP를 설치하면 PhpUnit 또한 패키지 매니저로 설치하는 것이 편리하다. 참고로 아래 코드는 [[ https://github.com/chwnam/vagrantwrapper| vagrantwrapper]] provision 스크립트에 포함되었다. 참고로 아래 WP-CLI에서 요구하는 PHPUnit은 4.8.X 버전을 요구하므로(출처?) 패키지 매니저를 통해 PHPUnit을 설치하는 것은 이 문서를 작성하는 2016년 1월 현재에는 적당하지 않다. 아래 스크립트처럼 직접 PHPUnit 을 받는 것이 적절하다. wget https://phar.phpunit.de/phpunit-old.phar -O /usr/local/bin/phpunit chmod +x /usr/local/bin/phpunit ==== WP-CLI ==== WP CLI는 앞으로 익혀 두는 것도 좋을 것 같다. 마찬가지로 아래 스크립트 또한 vagrantwrapper에 포함시켰다. wget https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -O /usr/local/bin/wp chmod +x /usr/local/bin/wp 위 과정을 거치면 필요한 패키지는 설치가 완료된다. 다음 내가 평소 사용하는 워드프레스 환경에 맞춰서 WP-CLI가 동작을 하게 하려면 약간의 커스터마이징이 필요하다. 다음 포인트를 꼭 맞추고, [[ http://wp-cli.org/config/ | WP-CLI config 문서]]를 참고하도록 한다. * CLI에서는 wp-config.php 에서 $_SERVER, $_SERVER['SERVER_NAME'] 항목은 사용할 수 없으므로 이 변수가 없을 경우를 대비한다. * 항상 wp-config.php 파일 내부에서 ABSPATH를 define 한다. 정확한 워드프레스 코어 파일을 지정하라. * ''require_once(ABSPATH . 'wp-settings.php');'' 구문은 반드시 wp-config.php 에 위치시킨다. WP-CLI는 wp-config.php 파일 내부에서 이 라인을 직접 읽어 처리한다. 이 구문을 찾지 못하면 WP-CLI는 에러를 출력한다. https://github.com/wp-cli/wp-cli/wiki/FAQ 링크의 'PHP Fatal error: Cannot redeclare wp_unregister_GLOBALS()' 부분을 참고. 아래는 ~/.wp-cli/config.yml 의 예제이다. path: /home/vagrant/shared/php/wordpress/wp-core url: http://wordpress.vagrant:8080 user: changwoo disabled_commands: - db drop 아래는 wp-config.php 의 예제이다. ==== 기타 ==== 나중에 실행될 ''install-wp-tests.sh''는 SVN, cURL을 요구한다. sudo apt-get install subversion curl ===== 테스트 환경 만들기 ===== WP-CLI를 이용하면 매우 간결하게 테스트 환경을 구비할 수 있다. 아래 명령을 통해 플러그인의 테스트 환경을 시작할 수 있다. wp scaffold plugin-tests 플러그인 디렉토리에 가 보면 다음과 같은 디렉토리가 부가적으로 생성된 것을 확인할 수 있다. * bin/ * install-wp-test.sh * tests/ * bootstrap.php * test-sample.php * phpunit.xml * .travis.yml 테스트 환경을 만드는 쉘 스크립트가 ''bin/install-wp-test.sh''로 만들어진 것을 확인할 수 있다. 이 스크립트는 워드프레스 개발 버전 관리 시스템 서버, SVN에서 testing 관련된 소스들을 가져 온다. 예전에는 이것을 수동으로 해 줬었는데 WP-CLI가 지원을 하는 것으로 보인다. 테스트를 위한 DB를 세팅, 설정하는 과정이 필요하다. 다음 명령으로 실행한다. ./install-wp-tests.sh [db-host] [wp-version] 이 스크립트는 새로운 DB를 생성하기 때문에, db-name은 기존에 사용 중인 데이터베이스를 쓰면 안 된다. 그리고 DB를 생성해야 하므로 db-user, db-pass 항목은 DB를 생성할 권한이 있는 사용자여야 하는 점을 주의한다. 테스트는 플러그인 디렉토리에서 ''phpunit'' 명령으로 실행 가능하다. 이 때 플러그인의 메인 파일 이름은 ''tests/bootstrap.php''에서 수정 가능하다. function _manually_load_plugin() { require dirname( dirname( __FILE__ ) ) . '/pluginTestSample.php'; } ===== 워드프레스의 팩토리 ===== 워드프레스 플러그인의 테스트는 ''WP_UnitTestCase'' 클래스를 확장하여 이뤄진다. 이 클래스는 팩토리 클래스를 제공한다. 이 팩토리 클래스를 이용하면, 워드프레스에서 관리하는 여러 오브젝트를 매우 편리하게 만들 수 있다. 가령 포스트를 만드려면, 다음과 같이 코드를 작성한다. $post_id = $this->factory->post->create( array( 'post_title' => 'Test Post' ); 여러 레코드를 생성하는 것도 가능하다 $post_ids = $this->factory->post->create_many( 10 ); 기본적으로 제공하는 팩토리는 다음과 같다. $this->post = new WP_UnitTest_Factory_For_Post( $this ); $this->attachment = new WP_UnitTest_Factory_For_Attachment( $this ); $this->comment = new WP_UnitTest_Factory_For_Comment( $this ); $this->user = new WP_UnitTest_Factory_For_User( $this ); $this->term = new WP_UnitTest_Factory_For_Term( $this ); $this->category = new WP_UnitTest_Factory_For_Term( $this, 'category' ); $this->tag = new WP_UnitTest_Factory_For_Term( $this, 'post_tag' ); if ( is_multisite() ) { $this->blog = new WP_UnitTest_Factory_For_Blog( $this ); $this->network = new WP_UnitTest_Factory_For_Network( $this ); } ===== 참고 자료 ===== * [[https://pippinsplugins.com/unit-tests-wordpress-plugins-introduction/ | Unit Tests for WordPress Plugins - An Introduction]] * http://wp-cli.org/ * http://wp-cli.org/blog/plugin-unit-tests.html