mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			124 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /**
 | |
|  *  Copyright (C) 2011 Cloud.com, Inc.  All rights reserved.
 | |
|  * 
 | |
|  * This software is licensed under the GNU General Public License v3 or later.
 | |
|  * 
 | |
|  * It is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or any later version.
 | |
|  * This program 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 General Public License for more details.
 | |
|  * 
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  * 
 | |
|  */
 | |
| package com.cloud.upgrade;
 | |
| 
 | |
| import java.sql.Connection;
 | |
| import java.sql.PreparedStatement;
 | |
| import java.sql.ResultSet;
 | |
| import java.sql.SQLException;
 | |
| import java.util.ArrayList;
 | |
| import java.util.List;
 | |
| 
 | |
| import junit.framework.TestCase;
 | |
| 
 | |
| import org.apache.log4j.Logger;
 | |
| import org.junit.After;
 | |
| import org.junit.Before;
 | |
| 
 | |
| import com.cloud.utils.component.ComponentLocator;
 | |
| import com.cloud.utils.db.DbTestUtils;
 | |
| import com.cloud.utils.db.Transaction;
 | |
| import com.cloud.utils.exception.CloudRuntimeException;
 | |
| 
 | |
| public class Template2214To30UpgradeTest extends TestCase {
 | |
|     private static final Logger s_logger = Logger
 | |
|             .getLogger(Template2214To30UpgradeTest.class);
 | |
| 
 | |
|     @Override
 | |
|     @Before
 | |
|     public void setUp() throws Exception {
 | |
|         DbTestUtils.executeScript("fake.sql", false,
 | |
|                 true);
 | |
|     }
 | |
| 
 | |
|     @Override
 | |
|     @After
 | |
|     public void tearDown() throws Exception {
 | |
|     }
 | |
| 
 | |
|     public void test2214to30Upgrade() throws SQLException {
 | |
|         s_logger.debug("Finding sample data from 2.2.14");
 | |
|         DbTestUtils.executeScript(
 | |
|                 "fake.sql", false,
 | |
|                 true);
 | |
| 
 | |
|         DatabaseUpgradeChecker checker = ComponentLocator
 | |
|                 .inject(DatabaseUpgradeChecker.class);
 | |
| 
 | |
|         checker.upgrade("2.2.14", "3.0.0");
 | |
| 
 | |
|         Connection conn = Transaction.getStandaloneConnection();
 | |
| 
 | |
|         try {
 | |
|             checkSystemVm(conn);
 | |
|         } finally {
 | |
|             try {
 | |
|                 conn.close();
 | |
|             } catch (SQLException e) {
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     protected void checkSystemVm(Connection conn) throws SQLException {
 | |
|         PreparedStatement pstmt;
 | |
| 
 | |
|         pstmt = conn
 | |
|                 .prepareStatement("SELECT version FROM `cloud`.`version` ORDER BY id DESC LIMIT 1");
 | |
|         ResultSet rs = pstmt.executeQuery();
 | |
|         assert rs.next() : "No version selected";
 | |
|         assert rs.getString(1).equals("3.0.0") : "VERSION stored is not 3.0.0: "
 | |
|                 + rs.getString(1);
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
| 
 | |
|         pstmt = conn.prepareStatement("select id from vm_template where name='systemvm-xenserver-3.0.0' and removed is null");
 | |
|         rs = pstmt.executeQuery();
 | |
|         long templateId1 = rs.getLong(1);
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
|         
 | |
|         pstmt = conn.prepareStatement("select distinct(vm_template_id) from vm_instance where type <> 'USER' and hypervisor_type = 'XenServer'");
 | |
|         rs = pstmt.executeQuery();
 | |
|         long templateId = rs.getLong(1);
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
| 
 | |
|         assert (templateId ==  templateId1) : "XenServer System Vms not using 3.0.0 template";
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
|         
 | |
|         pstmt = conn.prepareStatement("select id from vm_template where name='systemvm-kvm-3.0.0' and removed is null");
 | |
|         rs = pstmt.executeQuery();
 | |
|         long templateId3 = rs.getLong(1);
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
|         
 | |
|         pstmt = conn.prepareStatement("select distinct(vm_template_id) from vm_instance where type <> 'USER' and hypervisor_type = 'KVM'");
 | |
|         rs = pstmt.executeQuery();
 | |
|         long templateId4 = rs.getLong(1);
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
| 
 | |
|         assert (templateId3 ==  templateId4) : "KVM System Vms not using 3.0.0 template";
 | |
|         rs.close();
 | |
|         pstmt.close();
 | |
| 
 | |
|     }
 | |
| 
 | |
| }
 |