/*
Copyright 2009-2019 Igor Polevoy

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

package org.javalite.activejdbc.test;

import org.javalite.activejdbc.Base;
import org.junit.*;
import org.junit.runners.MethodSorters;

import java.sql.SQLException;

/**
 * WARNING: all methods in this test need to be executed sequentially in order to succeed.
 * They depend on each other.
 *
 * @author igor on 12/3/16.
 */
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
public class DBSpecTest extends DBSpec{

    @Before
    public void before() throws SQLException {
        DefaultDBReset.tryGenSchema();
    }

    @Test
    public void a_clean(){
        setRollback(false);
        Base.exec("delete from patients");
    }

    @Test
    public void b_shouldHaveConnectionToTestDB(){
        a(Base.connection()).shouldNotBeNull();
    }

    @Test
    public void c_shouldRollBackTransactionByDefault(){
        Base.exec("insert into patients (first_name, last_name) values ('Billie', 'Holiday')");
    }

    @Test
    public void d_shouldNotFindRecordsFromRolledBackTransaction(){
        a(Base.count("patients")).shouldBeEqual(0);
    }

    @Test
    public void e_should_NOT_RollBackTransaction(){
        setRollback(false); //  here, we are leaving data in DB for the next test to find (no rollback at the end of test)
        Base.exec("insert into patients (first_name, last_name) values ('Billie', 'Holiday')");
    }

    @Test
    public void f_shouldFindRecordsFromPrevious_NOT_Rolledback_Transaction(){
        a(Base.count("patients")).shouldBeEqual(1);

        //lets cleanup after ourselves just in case
        setRollback(false);
        Base.exec("delete from patients");
    }
}