mirror of
https://github.com/iSoron/uhabits.git
synced 2025-12-06 09:08:52 -06:00
Implement SQLiteRepository
This commit is contained in:
@@ -0,0 +1,191 @@
|
||||
/*
|
||||
* Copyright (C) 2016 Álinson Santos Xavier <isoron@gmail.com>
|
||||
*
|
||||
* This file is part of Loop Habit Tracker.
|
||||
*
|
||||
* Loop Habit Tracker 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 (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* Loop Habit Tracker 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 org.isoron.uhabits.models.sqlite;
|
||||
|
||||
import android.database.sqlite.*;
|
||||
import android.support.test.runner.*;
|
||||
import android.test.suitebuilder.annotation.*;
|
||||
|
||||
import com.activeandroid.*;
|
||||
|
||||
import org.apache.commons.lang3.builder.*;
|
||||
import org.isoron.androidbase.storage.*;
|
||||
import org.isoron.uhabits.*;
|
||||
import org.junit.*;
|
||||
import org.junit.runner.*;
|
||||
|
||||
import static org.hamcrest.core.IsEqual.*;
|
||||
import static org.junit.Assert.assertThat;
|
||||
|
||||
@RunWith(AndroidJUnit4.class)
|
||||
@MediumTest
|
||||
public class SQLiteRepositoryTest extends BaseAndroidTest
|
||||
{
|
||||
private SQLiteRepository<ThingRecord> repository;
|
||||
|
||||
private SQLiteDatabase db;
|
||||
|
||||
@Before
|
||||
@Override
|
||||
public void setUp()
|
||||
{
|
||||
super.setUp();
|
||||
repository =
|
||||
new SQLiteRepository<>(ThingRecord.class, Cache.openDatabase());
|
||||
|
||||
db = Cache.openDatabase();
|
||||
db.execSQL("drop table if exists tests");
|
||||
db.execSQL("create table tests(" +
|
||||
"id integer not null primary key autoincrement, " +
|
||||
"color_number integer not null, score float not null, " +
|
||||
"name string not null)");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFind() throws Exception
|
||||
{
|
||||
db.execSQL("insert into tests(id, color_number, name, score) " +
|
||||
"values (10, 20, 'hello', 8.0)");
|
||||
|
||||
ThingRecord record = repository.find(10L);
|
||||
|
||||
assertNotNull(record);
|
||||
assertThat(record.id, equalTo(10L));
|
||||
assertThat(record.color, equalTo(20));
|
||||
assertThat(record.name, equalTo("hello"));
|
||||
assertThat(record.score, equalTo(8.0));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSave_withId() throws Exception
|
||||
{
|
||||
ThingRecord record = new ThingRecord();
|
||||
record.id = 50L;
|
||||
record.color = 10;
|
||||
record.name = "hello";
|
||||
record.score = 5.0;
|
||||
repository.save(record);
|
||||
assertThat(record, equalTo(repository.find(50L)));
|
||||
|
||||
record.name = "world";
|
||||
record.score = 128.0;
|
||||
repository.save(record);
|
||||
assertThat(record, equalTo(repository.find(50L)));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSave_withoutId() throws Exception
|
||||
{
|
||||
ThingRecord r1 = new ThingRecord();
|
||||
r1.color = 10;
|
||||
r1.name = "hello";
|
||||
r1.score = 16.0;
|
||||
repository.save(r1);
|
||||
|
||||
ThingRecord r2 = new ThingRecord();
|
||||
r2.color = 20;
|
||||
r2.name = "world";
|
||||
r2.score = 2.0;
|
||||
repository.save(r2);
|
||||
|
||||
assertThat(r1.id, equalTo(1L));
|
||||
assertThat(r2.id, equalTo(2L));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testRemove() throws Exception
|
||||
{
|
||||
ThingRecord rec1 = new ThingRecord();
|
||||
rec1.color = 10;
|
||||
rec1.name = "hello";
|
||||
rec1.score = 16.0;
|
||||
repository.save(rec1);
|
||||
|
||||
ThingRecord rec2 = new ThingRecord();
|
||||
rec2.color = 20;
|
||||
rec2.name = "world";
|
||||
rec2.score = 32.0;
|
||||
repository.save(rec2);
|
||||
|
||||
long id = rec1.id;
|
||||
assertThat(rec1, equalTo(repository.find(id)));
|
||||
assertThat(rec2, equalTo(repository.find(rec2.id)));
|
||||
|
||||
repository.remove(rec1);
|
||||
assertThat(rec1.id, equalTo(null));
|
||||
assertNull(repository.find(id));
|
||||
assertThat(rec2, equalTo(repository.find(rec2.id)));
|
||||
|
||||
repository.remove(rec1); // should have no effect
|
||||
assertNull(repository.find(id));
|
||||
}
|
||||
}
|
||||
|
||||
@Table(name = "tests")
|
||||
class ThingRecord
|
||||
{
|
||||
@Column
|
||||
public Long id;
|
||||
|
||||
@Column
|
||||
public String name;
|
||||
|
||||
@Column(name = "color_number")
|
||||
public Integer color;
|
||||
|
||||
@Column
|
||||
public Double score;
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o)
|
||||
{
|
||||
if (this == o) return true;
|
||||
|
||||
if (o == null || getClass() != o.getClass()) return false;
|
||||
|
||||
ThingRecord record = (ThingRecord) o;
|
||||
|
||||
return new EqualsBuilder()
|
||||
.append(id, record.id)
|
||||
.append(name, record.name)
|
||||
.append(color, record.color)
|
||||
.isEquals();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
{
|
||||
return new HashCodeBuilder(17, 37)
|
||||
.append(id)
|
||||
.append(name)
|
||||
.append(color)
|
||||
.toHashCode();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return new ToStringBuilder(this)
|
||||
.append("id", id)
|
||||
.append("name", name)
|
||||
.append("color", color)
|
||||
.toString();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user