Interview

10 Android Unit Testing Interview Questions and Answers

Prepare for your Android developer interview with this guide on unit testing. Enhance your skills and ensure your applications are reliable and maintainable.

Android unit testing is a crucial aspect of ensuring the reliability and performance of mobile applications. By isolating and testing individual components, developers can identify and fix bugs early in the development process, leading to more robust and maintainable code. With the growing complexity of Android applications, mastering unit testing has become an essential skill for developers aiming to deliver high-quality software.

This article offers a curated selection of Android unit testing questions and answers to help you prepare for technical interviews. By familiarizing yourself with these questions, you can gain a deeper understanding of unit testing principles and demonstrate your proficiency in creating reliable Android applications.

Android Unit Testing Interview Questions and Answers

1. How do you set up a basic unit test in an Android project using JUnit?

To set up a basic unit test in an Android project using JUnit, follow these steps:

1. Add the JUnit dependency to your project’s build.gradle file.
2. Create a test class in the appropriate test directory.
3. Write test methods annotated with

@Test
@Test.

JUnit is a widely used testing framework in Android development. By adding the JUnit dependency, you can write and run tests to ensure your code behaves as expected.

Example:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
// build.gradle (Module: app)
dependencies {
testImplementation 'junit:junit:4.13.2'
}
// ExampleUnitTest.java
import org.junit.Test;
import static org.junit.Assert.*;
public class ExampleUnitTest {
@Test
public void addition_isCorrect() {
assertEquals(4, 2 + 2);
}
}
// build.gradle (Module: app) dependencies { testImplementation 'junit:junit:4.13.2' } // ExampleUnitTest.java import org.junit.Test; import static org.junit.Assert.*; public class ExampleUnitTest { @Test public void addition_isCorrect() { assertEquals(4, 2 + 2); } }
// build.gradle (Module: app)
dependencies {
    testImplementation 'junit:junit:4.13.2'
}

// ExampleUnitTest.java
import org.junit.Test;
import static org.junit.Assert.*;

public class ExampleUnitTest {
    @Test
    public void addition_isCorrect() {
        assertEquals(4, 2 + 2);
    }
}

In the build.gradle file, the JUnit dependency is added under the dependencies section. The test class,

ExampleUnitTest
ExampleUnitTest, is created in the
src/test/java
src/test/java directory. The test method,
addition_isCorrect
addition_isCorrect, uses the
assertEquals
assertEquals method to check if the addition of 2 and 2 equals 4.

2. What is Mockito and how is it used in Android unit testing?

Mockito is a framework that allows you to create mock objects in your unit tests. In Android development, it is often used to mock dependencies and verify interactions, making it easier to test components in isolation. Mockito provides a fluent API for creating mocks, stubbing methods, and verifying interactions.

Example:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
import static org.mockito.Mockito.*;
public class UserServiceTest {
@Test
public void testGetUser() {
// Create a mock object of UserRepository
UserRepository mockRepository = mock(UserRepository.class);
// Define the behavior of the mock object
when(mockRepository.getUser("123")).thenReturn(new User("John Doe"));
// Use the mock object in the service
UserService userService = new UserService(mockRepository);
User user = userService.getUser("123");
// Verify the interaction and assert the result
verify(mockRepository).getUser("123");
assertEquals("John Doe", user.getName());
}
}
import static org.mockito.Mockito.*; public class UserServiceTest { @Test public void testGetUser() { // Create a mock object of UserRepository UserRepository mockRepository = mock(UserRepository.class); // Define the behavior of the mock object when(mockRepository.getUser("123")).thenReturn(new User("John Doe")); // Use the mock object in the service UserService userService = new UserService(mockRepository); User user = userService.getUser("123"); // Verify the interaction and assert the result verify(mockRepository).getUser("123"); assertEquals("John Doe", user.getName()); } }
import static org.mockito.Mockito.*;

public class UserServiceTest {

    @Test
    public void testGetUser() {
        // Create a mock object of UserRepository
        UserRepository mockRepository = mock(UserRepository.class);

        // Define the behavior of the mock object
        when(mockRepository.getUser("123")).thenReturn(new User("John Doe"));

        // Use the mock object in the service
        UserService userService = new UserService(mockRepository);
        User user = userService.getUser("123");

        // Verify the interaction and assert the result
        verify(mockRepository).getUser("123");
        assertEquals("John Doe", user.getName());
    }
}

In this example,

UserRepository
UserRepository is mocked to return a predefined
User
User object when its
getUser
getUser method is called. This allows the
UserService
UserService to be tested in isolation without relying on the actual implementation of
UserRepository
UserRepository.

3. Write a unit test to verify a method that calculates the sum of two integers.

Unit testing is a type of software testing where individual units or components of a software are tested. The purpose is to validate that each unit of the software performs as expected. In Android development, unit tests are typically written using the JUnit framework. These tests help ensure that methods and classes work correctly in isolation, which can prevent bugs and improve code quality.

Here is an example of a unit test for a method that calculates the sum of two integers using JUnit:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
public class Calculator {
public int sum(int a, int b) {
return a + b;
}
}
import static org.junit.Assert.assertEquals;
import org.junit.Test;
public class CalculatorTest {
@Test
public void testSum() {
Calculator calculator = new Calculator();
int result = calculator.sum(2, 3);
assertEquals(5, result);
}
}
public class Calculator { public int sum(int a, int b) { return a + b; } } import static org.junit.Assert.assertEquals; import org.junit.Test; public class CalculatorTest { @Test public void testSum() { Calculator calculator = new Calculator(); int result = calculator.sum(2, 3); assertEquals(5, result); } }
public class Calculator {
    public int sum(int a, int b) {
        return a + b;
    }
}

import static org.junit.Assert.assertEquals;
import org.junit.Test;

public class CalculatorTest {
    @Test
    public void testSum() {
        Calculator calculator = new Calculator();
        int result = calculator.sum(2, 3);
        assertEquals(5, result);
    }
}

In this example, the Calculator class has a method

sum
sum that takes two integers and returns their sum. The CalculatorTest class contains a unit test for the
sum
sum method. The
testSum
testSum method creates an instance of
Calculator
Calculator, calls the
sum
sum method with the integers 2 and 3, and asserts that the result is 5 using the
assertEquals
assertEquals method from JUnit.

4. Write a unit test for a method that fetches data from a remote API using Retrofit.

When testing methods that fetch data from a remote API using Retrofit, it is important to mock the API responses to isolate the unit of code being tested. This ensures that the test is not dependent on the actual network call, making it faster and more reliable.

Here is an example of how to write a unit test for a method that fetches data from a remote API using Retrofit:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
// Retrofit API interface
public interface ApiService {
@GET("data")
Call<Data> fetchData();
}
// Data model
public class Data {
private String value;
// getters and setters
}
// Repository class
public class DataRepository {
private ApiService apiService;
public DataRepository(ApiService apiService) {
this.apiService = apiService;
}
public void getData(Callback<Data> callback) {
apiService.fetchData().enqueue(callback);
}
}
// Unit test
@RunWith(MockitoJUnitRunner.class)
public class DataRepositoryTest {
@Mock
private ApiService apiService;
@Mock
private Callback<Data> callback;
private DataRepository dataRepository;
@Before
public void setUp() {
dataRepository = new DataRepository(apiService);
}
@Test
public void testFetchData() {
Data mockData = new Data();
mockData.setValue("test");
Call<Data> mockCall = Mockito.mock(Call.class);
Mockito.when(apiService.fetchData()).thenReturn(mockCall);
dataRepository.getData(callback);
Mockito.verify(apiService).fetchData();
Mockito.verify(mockCall).enqueue(callback);
}
}
// Retrofit API interface public interface ApiService { @GET("data") Call<Data> fetchData(); } // Data model public class Data { private String value; // getters and setters } // Repository class public class DataRepository { private ApiService apiService; public DataRepository(ApiService apiService) { this.apiService = apiService; } public void getData(Callback<Data> callback) { apiService.fetchData().enqueue(callback); } } // Unit test @RunWith(MockitoJUnitRunner.class) public class DataRepositoryTest { @Mock private ApiService apiService; @Mock private Callback<Data> callback; private DataRepository dataRepository; @Before public void setUp() { dataRepository = new DataRepository(apiService); } @Test public void testFetchData() { Data mockData = new Data(); mockData.setValue("test"); Call<Data> mockCall = Mockito.mock(Call.class); Mockito.when(apiService.fetchData()).thenReturn(mockCall); dataRepository.getData(callback); Mockito.verify(apiService).fetchData(); Mockito.verify(mockCall).enqueue(callback); } }
// Retrofit API interface
public interface ApiService {
    @GET("data")
    Call<Data> fetchData();
}

// Data model
public class Data {
    private String value;
    // getters and setters
}

// Repository class
public class DataRepository {
    private ApiService apiService;

    public DataRepository(ApiService apiService) {
        this.apiService = apiService;
    }

    public void getData(Callback<Data> callback) {
        apiService.fetchData().enqueue(callback);
    }
}

// Unit test
@RunWith(MockitoJUnitRunner.class)
public class DataRepositoryTest {

    @Mock
    private ApiService apiService;

    @Mock
    private Callback<Data> callback;

    private DataRepository dataRepository;

    @Before
    public void setUp() {
        dataRepository = new DataRepository(apiService);
    }

    @Test
    public void testFetchData() {
        Data mockData = new Data();
        mockData.setValue("test");

        Call<Data> mockCall = Mockito.mock(Call.class);
        Mockito.when(apiService.fetchData()).thenReturn(mockCall);

        dataRepository.getData(callback);

        Mockito.verify(apiService).fetchData();
        Mockito.verify(mockCall).enqueue(callback);
    }
}

5. How do you mock dependencies in Android unit tests using Dagger or Hilt?

Mocking dependencies in Android unit tests is essential for isolating the unit of work being tested. Dagger and Hilt are popular dependency injection frameworks that can be used to manage dependencies in Android applications. When writing unit tests, you can use these frameworks to provide mock implementations of dependencies, ensuring that the tests are not affected by the actual implementations.

To mock dependencies using Dagger or Hilt, you typically create a test-specific component or module that provides the mock implementations. This allows you to inject the mocks into the classes under test.

Example using Hilt:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
@HiltAndroidTest
class MyViewModelTest {
@get:Rule
var hiltRule = HiltAndroidRule(this)
@Inject
lateinit var myRepository: MyRepository
@Before
fun init() {
hiltRule.inject()
}
@Test
fun testMyViewModel() {
// Use mock implementation of MyRepository
}
}
@Module
@TestInstallIn(
components = [SingletonComponent::class],
replaces = [AppModule::class]
)
object TestModule {
@Provides
fun provideMyRepository(): MyRepository {
return mock(MyRepository::class.java)
}
}
@HiltAndroidTest class MyViewModelTest { @get:Rule var hiltRule = HiltAndroidRule(this) @Inject lateinit var myRepository: MyRepository @Before fun init() { hiltRule.inject() } @Test fun testMyViewModel() { // Use mock implementation of MyRepository } } @Module @TestInstallIn( components = [SingletonComponent::class], replaces = [AppModule::class] ) object TestModule { @Provides fun provideMyRepository(): MyRepository { return mock(MyRepository::class.java) } }
@HiltAndroidTest
class MyViewModelTest {

    @get:Rule
    var hiltRule = HiltAndroidRule(this)

    @Inject
    lateinit var myRepository: MyRepository

    @Before
    fun init() {
        hiltRule.inject()
    }

    @Test
    fun testMyViewModel() {
        // Use mock implementation of MyRepository
    }
}

@Module
@TestInstallIn(
    components = [SingletonComponent::class],
    replaces = [AppModule::class]
)
object TestModule {

    @Provides
    fun provideMyRepository(): MyRepository {
        return mock(MyRepository::class.java)
    }
}

6. How do you write parameterized tests in JUnit for Android?

Parameterized tests in JUnit for Android allow you to run the same test with different inputs. This is particularly useful for testing various scenarios without writing multiple test methods. JUnit provides the

@RunWith
@RunWith and
@Parameters
@Parameters annotations to facilitate parameterized tests.

Here is an example of how to write parameterized tests in JUnit for Android:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import java.util.Arrays;
import java.util.Collection;
import static org.junit.Assert.assertEquals;
@RunWith(Parameterized.class)
public class ParameterizedTest {
private int input;
private int expectedOutput;
public ParameterizedTest(int input, int expectedOutput) {
this.input = input;
this.expectedOutput = expectedOutput;
}
@Parameterized.Parameters
public static Collection<Object[]> data() {
return Arrays.asList(new Object[][]{
{1, 2},
{2, 4},
{3, 6},
{4, 8}
});
}
@Test
public void testMultiplyByTwo() {
assertEquals(expectedOutput, input * 2);
}
}
import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import java.util.Arrays; import java.util.Collection; import static org.junit.Assert.assertEquals; @RunWith(Parameterized.class) public class ParameterizedTest { private int input; private int expectedOutput; public ParameterizedTest(int input, int expectedOutput) { this.input = input; this.expectedOutput = expectedOutput; } @Parameterized.Parameters public static Collection<Object[]> data() { return Arrays.asList(new Object[][]{ {1, 2}, {2, 4}, {3, 6}, {4, 8} }); } @Test public void testMultiplyByTwo() { assertEquals(expectedOutput, input * 2); } }
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;

import java.util.Arrays;
import java.util.Collection;

import static org.junit.Assert.assertEquals;

@RunWith(Parameterized.class)
public class ParameterizedTest {

    private int input;
    private int expectedOutput;

    public ParameterizedTest(int input, int expectedOutput) {
        this.input = input;
        this.expectedOutput = expectedOutput;
    }

    @Parameterized.Parameters
    public static Collection<Object[]> data() {
        return Arrays.asList(new Object[][]{
                {1, 2},
                {2, 4},
                {3, 6},
                {4, 8}
        });
    }

    @Test
    public void testMultiplyByTwo() {
        assertEquals(expectedOutput, input * 2);
    }
}

In this example, the @RunWith(Parameterized.class) annotation tells JUnit to run the test class as a parameterized test. The @Parameters annotation is used to define the data set, which is a collection of input and expected output pairs. The test method

testMultiplyByTwo
testMultiplyByTwo is then executed for each pair of input and expected output.

7. How do you use Robolectric for unit testing in Android?

Robolectric is a framework that allows you to run Android tests directly on the JVM, which makes the testing process faster and more efficient. It provides a way to simulate the Android environment and run tests without the need for an emulator or physical device.

To use Robolectric for unit testing in Android, you need to add the Robolectric dependency to your project. This is typically done in the build.gradle file:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
testImplementation 'org.robolectric:robolectric:4.6.1'
testImplementation 'org.robolectric:robolectric:4.6.1'
testImplementation 'org.robolectric:robolectric:4.6.1'

Once the dependency is added, you can write your test cases using standard JUnit annotations. Robolectric provides a

RobolectricTestRunner
RobolectricTestRunner that you can use to run your tests. Here is an example of a simple unit test using Robolectric:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
@RunWith(RobolectricTestRunner.class)
public class MainActivityTest {
@Test
public void clickingButton_shouldChangeText() {
MainActivity activity = Robolectric.setupActivity(MainActivity.class);
Button button = activity.findViewById(R.id.button);
TextView textView = activity.findViewById(R.id.textView);
button.performClick();
assertEquals("Button Clicked", textView.getText().toString());
}
}
@RunWith(RobolectricTestRunner.class) public class MainActivityTest { @Test public void clickingButton_shouldChangeText() { MainActivity activity = Robolectric.setupActivity(MainActivity.class); Button button = activity.findViewById(R.id.button); TextView textView = activity.findViewById(R.id.textView); button.performClick(); assertEquals("Button Clicked", textView.getText().toString()); } }
@RunWith(RobolectricTestRunner.class)
public class MainActivityTest {

    @Test
    public void clickingButton_shouldChangeText() {
        MainActivity activity = Robolectric.setupActivity(MainActivity.class);

        Button button = activity.findViewById(R.id.button);
        TextView textView = activity.findViewById(R.id.textView);

        button.performClick();

        assertEquals("Button Clicked", textView.getText().toString());
    }
}

In this example, the

RobolectricTestRunner
RobolectricTestRunner is used to run the test. The
Robolectric.setupActivity
Robolectric.setupActivity method is used to create an instance of the
MainActivity
MainActivity. The test then simulates a button click and checks if the text in the
TextView
TextView has changed accordingly.

8. Write a unit test for a ViewModel in an MVVM architecture.

Unit testing in an MVVM (Model-View-ViewModel) architecture is important for ensuring that the ViewModel behaves as expected. The ViewModel is responsible for preparing and managing the data for the View, and it acts as a bridge between the Model and the View. Unit tests for ViewModels typically involve verifying that the ViewModel correctly processes input and updates its state.

Here is an example of how to write a unit test for a ViewModel in an MVVM architecture using Kotlin and JUnit:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
// ViewModel class
class MyViewModel(private val repository: MyRepository) : ViewModel() {
val data: LiveData<String> = MutableLiveData()
fun fetchData() {
val result = repository.getData()
(data as MutableLiveData).value = result
}
}
// Unit test class
class MyViewModelTest {
private lateinit var viewModel: MyViewModel
private val repository = mock(MyRepository::class.java)
@Before
fun setUp() {
viewModel = MyViewModel(repository)
}
@Test
fun fetchData_updatesLiveData() {
// Arrange
val expectedData = "Hello, World!"
`when`(repository.getData()).thenReturn(expectedData)
// Act
viewModel.fetchData()
// Assert
assertEquals(expectedData, viewModel.data.value)
}
}
// ViewModel class class MyViewModel(private val repository: MyRepository) : ViewModel() { val data: LiveData<String> = MutableLiveData() fun fetchData() { val result = repository.getData() (data as MutableLiveData).value = result } } // Unit test class class MyViewModelTest { private lateinit var viewModel: MyViewModel private val repository = mock(MyRepository::class.java) @Before fun setUp() { viewModel = MyViewModel(repository) } @Test fun fetchData_updatesLiveData() { // Arrange val expectedData = "Hello, World!" `when`(repository.getData()).thenReturn(expectedData) // Act viewModel.fetchData() // Assert assertEquals(expectedData, viewModel.data.value) } }
// ViewModel class
class MyViewModel(private val repository: MyRepository) : ViewModel() {
    val data: LiveData<String> = MutableLiveData()

    fun fetchData() {
        val result = repository.getData()
        (data as MutableLiveData).value = result
    }
}

// Unit test class
class MyViewModelTest {

    private lateinit var viewModel: MyViewModel
    private val repository = mock(MyRepository::class.java)

    @Before
    fun setUp() {
        viewModel = MyViewModel(repository)
    }

    @Test
    fun fetchData_updatesLiveData() {
        // Arrange
        val expectedData = "Hello, World!"
        `when`(repository.getData()).thenReturn(expectedData)

        // Act
        viewModel.fetchData()

        // Assert
        assertEquals(expectedData, viewModel.data.value)
    }
}

In this example, the

MyViewModel
MyViewModel class has a
fetchData
fetchData method that retrieves data from a repository and updates a LiveData object. The unit test
MyViewModelTest
MyViewModelTest sets up the ViewModel, mocks the repository, and verifies that the LiveData is updated correctly when
fetchData
fetchData is called.

9. How do you test LiveData in Android?

Testing LiveData in Android involves ensuring that the data is observed correctly and that the lifecycle events are handled properly. Since LiveData is lifecycle-aware, it requires special handling in unit tests to simulate the Android lifecycle.

To test LiveData, you can use the

InstantTaskExecutorRule
InstantTaskExecutorRule to ensure that LiveData updates happen instantly and on the same thread. Additionally, you can use a mock
Observer
Observer to observe the LiveData and verify the emitted values.

Example:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.Observer
import org.junit.Rule
import org.junit.Test
import org.mockito.Mockito.*
class LiveDataTest {
@get:Rule
val instantTaskExecutorRule = InstantTaskExecutorRule()
@Test
fun testLiveData() {
val liveData = MutableLiveData<String>()
val observer = mock(Observer::class.java) as Observer<String>
liveData.observeForever(observer)
liveData.value = "Hello, World!"
verify(observer).onChanged("Hello, World!")
}
}
import androidx.arch.core.executor.testing.InstantTaskExecutorRule import androidx.lifecycle.MutableLiveData import androidx.lifecycle.Observer import org.junit.Rule import org.junit.Test import org.mockito.Mockito.* class LiveDataTest { @get:Rule val instantTaskExecutorRule = InstantTaskExecutorRule() @Test fun testLiveData() { val liveData = MutableLiveData<String>() val observer = mock(Observer::class.java) as Observer<String> liveData.observeForever(observer) liveData.value = "Hello, World!" verify(observer).onChanged("Hello, World!") } }
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.Observer
import org.junit.Rule
import org.junit.Test
import org.mockito.Mockito.*

class LiveDataTest {

    @get:Rule
    val instantTaskExecutorRule = InstantTaskExecutorRule()

    @Test
    fun testLiveData() {
        val liveData = MutableLiveData<String>()
        val observer = mock(Observer::class.java) as Observer<String>

        liveData.observeForever(observer)
        liveData.value = "Hello, World!"

        verify(observer).onChanged("Hello, World!")
    }
}

In this example,

InstantTaskExecutorRule
InstantTaskExecutorRule ensures that LiveData updates are executed immediately. The
Observer
Observer is mocked to verify that it receives the correct value when LiveData is updated.

10. Write a unit test for a Room database DAO method.

Unit testing is important in Android development to ensure that individual components, such as Room database DAO methods, function correctly. When writing a unit test for a DAO method, it is essential to set up an in-memory database to avoid affecting the actual database. This allows for isolated and repeatable tests. The test should verify that the DAO methods perform the expected operations, such as inserting, querying, updating, and deleting data.

Example:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
@RunWith(AndroidJUnit4::class)
class UserDaoTest {
private lateinit var db: AppDatabase
private lateinit var userDao: UserDao
@Before
fun createDb() {
val context = ApplicationProvider.getApplicationContext<Context>()
db = Room.inMemoryDatabaseBuilder(context, AppDatabase::class.java).build()
userDao = db.userDao()
}
@After
fun closeDb() {
db.close()
}
@Test
fun testInsertAndRetrieveUser() {
val user = User(1, "John Doe")
userDao.insert(user)
val retrievedUser = userDao.getUserById(1)
assertEquals(user, retrievedUser)
}
}
@RunWith(AndroidJUnit4::class) class UserDaoTest { private lateinit var db: AppDatabase private lateinit var userDao: UserDao @Before fun createDb() { val context = ApplicationProvider.getApplicationContext<Context>() db = Room.inMemoryDatabaseBuilder(context, AppDatabase::class.java).build() userDao = db.userDao() } @After fun closeDb() { db.close() } @Test fun testInsertAndRetrieveUser() { val user = User(1, "John Doe") userDao.insert(user) val retrievedUser = userDao.getUserById(1) assertEquals(user, retrievedUser) } }
@RunWith(AndroidJUnit4::class)
class UserDaoTest {

    private lateinit var db: AppDatabase
    private lateinit var userDao: UserDao

    @Before
    fun createDb() {
        val context = ApplicationProvider.getApplicationContext<Context>()
        db = Room.inMemoryDatabaseBuilder(context, AppDatabase::class.java).build()
        userDao = db.userDao()
    }

    @After
    fun closeDb() {
        db.close()
    }

    @Test
    fun testInsertAndRetrieveUser() {
        val user = User(1, "John Doe")
        userDao.insert(user)
        val retrievedUser = userDao.getUserById(1)
        assertEquals(user, retrievedUser)
    }
}

In this example, the UserDaoTest class sets up an in-memory database and a DAO instance before each test and closes the database afterward. The testInsertAndRetrieveUser method inserts a user into the database and verifies that the user can be retrieved correctly.

Previous

10 Jamf Pro Interview Questions and Answers

Back to Interview
Next

10 Slowly Changing Dimensions Interview Questions and Answers