/*  PAT: Persistent Applications Toolkit (patsystem.sf.net)
 *  Copyright (C) 2004, 2005  Tomasz Nazar, nthx at irc dot pl
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2 of the License, or (at your option) any later version.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *  Full version of the license is /docs/LICENSE.txt
 */
package org.nthx.pat.demo;


import org.apache.log4j.Logger;
import org.nthx.pat.Persisteble;

/** 
 *  
 *  @version $Id: PerformanceDemo.java 3725 2005-06-09 23:57:03Z nthx $
 *  @author nthx@users.sourceforge.net
 */
public class PerformanceDemo
{

    private static int usersCount = 
        Integer.valueOf(System.getProperty("users.count", "1000")).intValue();

    public static void main(String[] args)
    {
        Forum forum = new Forum();
        log.debug("-= Finished creating Forum object =-");
        log.debug("-= Actual user number is: " + forum.getUsers().size());
        log.debug("-= Will try to put: " + usersCount + " new users..");

        String random;
        User user;
        Topic topic;
        String subject;

        String instance = "" + forum.getUsers().size();

        for (int i=0; i<usersCount; i++)
        {
            random = "" + instance + "/" + i;
            if (0 == i % 1000)
                log.debug("Iteration: " + i);

            user = forum.newUser("name: " + random,
                                  "surname: " + random, 
                                  "login: " + random,
                                  "www: http://www." + random);

            subject = "Subject: " + random; 
            topic = forum.newTopic(subject, user, "Already done...");

            forum.newMessage(user, topic, "Message: " + random);
        }


        log.debug("Users: " + forum.getUsers().size());

        if (System.getProperty("take.snapshot", "true").equals("true"))
            ((Persisteble)forum).takeSnapshot();
        log.debug("SUCCEED. Increase `users.size' variable value :)");

    }

    private static Logger log = Logger.getLogger("pat");
}