WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru

Заполняем данными сайт на WordPress (большим количеством постов) и комментариев (для тестирования)

Случилось, что нужно было протестировать кое-что на WordPress и нужно было, чтобы блог содержал много информации, большое количество постов и комментариев, т.е. нужно было большое количество контента. Решил быстренько написать пару функций для быстрого заполнения сайта огромным числом демо записей. В будущем думаю еще пригодится. Ну, а так как пригодится может не только мне, выкладываю результаты.

Вот код, ставить который можно в любимый function.php:

// ВАЖНО! Кодировка файла должна быть utf8 (без BOM)

// ?fill_db=3000&cats=1|3&tags=tag1|tag2|tag3
// ?fill_db_comments=3000

new Fill_DB; // включаем

class Fill_DB {

	function __construct(){
		add_filter('init', array( & $this, '__fill_db') );
	}

	function __fill_db(){
		wp_suspend_cache_addition( true ); // отключаем кэширование

		// Контент
		// ?fill_db=3000&cats=1|3&tags=tag1|tag2|tag3
		if( isset($_GET['fill_db']) ){
			$limit = (int) $_GET['fill_db'];
			if(!$limit || !is_numeric($limit)) $limit=50;

			$cats = $_GET['cats'] ? $_GET['cats'] : '1';
			$tags = $_GET['tags'] ? $_GET['tags'] : '';

			//запускаем цикл
			for( $i=1; $i<=$limit; $i++ ){
				$rand = (string) rand(1,99999);

				$content = '';
				for( $g=0; $g<30; $g++ )
					$content .= "очередная запись под случайным номером: $rand . ";

				$post_date = $this->get_random('2011|2012').'-0'.rand(1,9).'-'.rand(10,30).' 23:25:59';
				/*
				  'ID' =>               //[ <post id> ] Are you updating an existing post?
				  'comment_status' =>      //[ 'closed' | 'open' ]  'closed' means no comments.
				  'ping_status' =>         //[ 'closed' | 'open' ]  'closed' means pingbacks or trackbacks turned off. def:get_option('default_ping_status')
				  'post_author' =>         //[ <user ID> ] The user ID number of the author. def:$user_ID
				  'post_category' =>       //[ array(<category id>, <...>) ] Add some categories.
				  'post_content' =>        //[ <the text of the post> ] The full text of the post.
				  'post_date' =>           //[ Y-m-d H:i:s ] The time post was made.
				  'post_date_gmt' =>       //[ Y-m-d H:i:s ] The time post was made, in GMT.
				  'post_name' =>           //[ <the name> ]  The name (slug) for your post
				  'post_title' =>          //[ <the title> ] The title of your post.
				  'tags_input' =>          //[ '<tag>, <tag>, <...>' ] For tags.
				  'post_content_filtered' => '' // def:''
				  'post_parent' =>         //[ <post ID> ] Sets the parent of the new post. def:
				  'post_excerpt' =>        //[ <an excerpt> ] For all your post excerpt needs. def:
				  'menu_order' =>          //[ <order> ] If new post is a page, sets the order should it appear in the tabs. def:
				  'post_status' =>         //[ 'draft' | 'publish' | 'pending'| 'future' | 'private' ] Set the status of the new post. def:draft
				  'post_type' =>           //[ 'post' | 'page' ] Sometimes you want to post a page. def:post
				  'to_ping' =>             //[ ? ] ? def:
				  'pinged' =>              //[ ? ] ? def:
				  'guid' => ''             // def:''
				  'post_password' => //[ ? ] password for post? def:

				*/
				$postid = wp_insert_post( array(
					'comment_status' => $this->get_random('closed|open'),
					'ping_status'    => $this->get_random('closed|open'),
					'post_category'  => array( $this->get_random($cats) ),
					'post_title'     => "Запись со случайным номером $rand",
					'post_content'   => $content,
					'post_date'      => $post_date,
					'tags_input'     => $this->get_random($tags),
					'post_status'    => 'publish',
				) );

				if( $postid )
					$this->fill_db_with_metadata_add_views( $postid );

				//if($postid) echo $postid.", ";
				//else echo "error";
				flush();
			}
		}

		// Комменты
		// ?fill_db_comments=3000
		if( isset($_GET['fill_db_comments']) ){
			$limit = (int) $_GET['fill_db_comments'];
			if(!$limit || !is_numeric($limit)) $limit=50;

			global $wpdb;
			$IDs = $wpdb->get_results("SELECT ID FROM $wpdb->posts WHERE post_status='publish' AND post_type='post' AND comment_status='open' ORDER BY rand() LIMIT 150", ARRAY_A);
			foreach($IDs as $v) $IDsfix[] = $v['ID'];

			//запускаем цикл
			for($i=1; $i<=$limit; $i++){
				$rand = (string) rand(1,99999);

				$content = '';
				for($g=0; $g<5; $g++)
					$content .= "комментарий: $rand . ";
				$post_date = $this->get_random('2009|2011').'-0'.rand(1,9).'-'.rand(10,30).' 23:25:59';

				/*
				$data = array(
					'comment_post_ID' => 1,
					'comment_author' => 'admin',
					'comment_author_email' => 'admin@admin.com',
					'comment_author_url' => 'http://',
					'comment_content' => 'content here',
					'comment_type' => ,
					'comment_parent' => 0,
					'user_id' => 1,
					'comment_author_IP' => '127.0.0.1',
					'comment_agent' => 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.10) Gecko/2009042316 Firefox/3.0.10 (.NET CLR 3.5.30729)',
					'comment_date' => $time,
					'comment_approved' => 1,
				);
				*/
				$postid = wp_insert_comment( array(
					'comment_post_ID' => array_rand($IDsfix),
					'comment_author' => 'commentator name',
					'comment_author_email' => 'admin@admin.com',
					'comment_author_url' => '',
					'comment_content' => $content,
					//'comment_type' =>,
					//'comment_parent' => 0,
					//'user_id' => 1,
					'comment_author_IP' => '127.0.0.1',
					'comment_agent' => 'Opera 10.0',
					'comment_date' => $post_date,
					'comment_approved' => 1,
				) );
				//if($postid) echo $postid.", ";
				//else echo "error";
				flush();
			}

		}
	}

	// Добавляем произвольное поле views к создаваемым постам
	function fill_db_with_metadata_add_views( $post_id ){
		$value = (string) rand(10,9999);
		update_post_meta( $post_id, 'views', $value );
	}

	function get_random( $data = '' ){
		$arg = explode('|', $data);
		$rand_key = array_rand($arg);
		return $arg[$rand_key];
	}

}

Объяснять подробно не буду что и зачем. В двух словах о том, как это работает:

Чтобы заполнить блог постами

Дописываем в УРЛ, нечто такое

?fill_db=3000&cats=1|3&tags=tag1|tag2|tag3

где, 3000 - сколько постов добавятся. cats=1|3 - посты будут случайно добавляться в категорию 1 или 3. tags=tag1|tag2|tag3 - постам будут приписана одна из меток (использовать кириллицу нельзя, указываем слаги).

У постов также заполняется произвольное поле views, куда пишутся просмотры. Отредактируйте функцию fill_db_with_metadata_add_views(), чтобы изменить добавление произвольных полей.

Чтобы заполнить комментариями

Дописываем в УРЛ, нечто такое

?fill_db_comments=3000

Комментарии будут "оставляться" к случайным постам, открытым для комментирования. 3000 - количество комментариев.

Что касается того, где это можно применить? Где угодно - заполняем блог и тестируем его скорость, при 100к постов явные "болячки" всплывают на ура. Тестить можно шаблоны, функции и отдельные запросы к БД или что-нибудь еще.

Тестирование отображения контента для темы

Для тестирования контента можно воспользоваться XML файлом для импорта данных. Это специальный файл созданный разработчиками WordPress для тестирования отображения контента. Он содержит информацию с постами, страницами, комментариями, категориями и другим контентом.

Для импорта этого файл используйте специальный плагин  WordPress Importer.

Для тестирования отображения виджетов создан простой плагин Monster Widget. Плагин дает возможность быстро и легко добавить все существующие виджеты в боковую панель для тестирования.

12 комментов
  • Serge

    Очень интересная идея. Сегодня протестирую и посмотрим, что получится!

    Ответить7.9 лет назад #
  • Dimox cайт: dimox.name

    Интересно. При подходящем случае применю.

    Ранее я использовал xml-файл, который предлагается в кодексе ВП для тестирования темы.

    Ответить7.9 лет назад #
  • zenken

    поделитесь плиз ссылочкой на плагин ваших комментов - очень нравится)

    Ответить7.3 лет назад #
    • Kama7019

      Это не плагин, это ручная работа. Плагин тут только кнопки: jQuery Comment Preview

      Ответить7.3 лет назад #
  • Чеснок cайт: pochesnomu.ru

    от счас мы это дело и рипнем laugh

    Ответить7 лет назад #
  • Виталий Капля cайт: www.dasayt.com

    Премного благодарен!

    Ответить6.7 лет назад #
  • campusboy3060 cайт: www.youtube.com/c/wpplus

    Я как-то оставлял в одном из комментариев скорость добавления статей у Wp. А тут и теги, и категории, и комментарии со статьями. Представляю, сколько надо ждать добавления 100к записей smile Не уверен, что хватит ночи даже.

    Ответить3.2 года назад #
    • Kama7019

      Да в ВП все не быстро. Ну не ночь, но часа 2 уйдет...

      Ответить3.2 года назад #
      • campusboy3060 cайт: www.youtube.com/c/wpplus

        У меня другие результаты. Два часа - это слишком оптимистичный прогноз. Да, WP насчёт этого страдает и это печалит. Может в будущем ситуация изменится.

        Ответить3.2 года назад #
  • @ Влад

    Здравствуйте, помогите! Создал сайт, купил домен, заплатил за хост, окончил регистрацию в поисковых системах, галочку которая отключает индексацию не ставил. Статей написал. Жду неделю. И ноль просмотров и в поисковике не отображается и на сайт никто кроме меня не заходил. Почему мой сайт недоступен пользователям? Сайт http://osnovypediatrii.ru
    Спасибо

    Ответить2 месяца назад #
Здравствуйте, !     Войти . Зарегистрироваться