Как написать android модульный тест? - PullRequest
2 голосов
/ 10 апреля 2020

Я новичок в TDD (тест-ориентированной разработке) написании кодов. Я знаю, что мы должны написать тест, который не прошел, а затем мы должны написать минимальный код, который бы прошел тест, и я понял базовые c примеры. Но когда я захотел реализовать это в своем коде, я застрял.

Ниже приведены два класса Класс MainActivity и Класс ImageData , и задача, которую я выполняю, довольно проста: взять изображение, рассчитать его размеры и проверить, для изображения имеется доступная память, и я соответственно устанавливаю метку. Теперь я хочу написать test ( Хотя я знаю, что тесты пишутся первыми. ) для функции getMeasure () в моем ImageData класс. То, что я не могу понять, это то, откуда я должен взять изображение для расчета его размеров. Должен ли я сохранить изображение в папке Drawable (на рабочем столе) или есть способ выбрать изображение из моего устройства android для теста.

Ниже приведены классы:

MainActivity class:

package com.example.test;

import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.os.StatFs;
import android.provider.MediaStore;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.io.File;

import static android.provider.Telephony.ThreadsColumns.ERROR;

public class MainActivity extends Activity {


    private static int LOAD_IMAGE = 1;


    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button buttonLoadImage = findViewById(R.id.space);
        buttonLoadImage.setOnClickListener((View view)-> {
                Intent i = new Intent(
                        Intent.ACTION_PICK,
                        android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);
                startActivityForResult(i, LOAD_IMAGE);
        });
    }


    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode == LOAD_IMAGE && resultCode == RESULT_OK && data != null) {
            Uri selectedImage = data.getData();

            //getting the image detail
            String[] filePathColumn = { MediaStore.Images.Media.DATA };
            Cursor cursor = getContentResolver().query(selectedImage,
                    filePathColumn, null, null, null);
            cursor.moveToFirst();
            int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
            String picturePath = cursor.getString(columnIndex);

            //calculating dimension of the imaage
            ImageData imageData = new ImageData(new File(picturePath));
            int[] a = new int[2];
            a = imageData.getMeasure();
            double size = a[0] * a[1] ;
            size /= (8*1024*1024.0);
            size *= 32;

            //Setting textview
            TextView storage = findViewById(R.id.storage);
            storage.setText("Available storage : "+getAvailableExternalMemorySize());
            TextView image = findViewById(R.id.image);
            image.setText("Size of Image : "+size);
            TextView available =  findViewById(R.id.available);

            double memory = Double.parseDouble(getAvailableExternalMemorySize());
            if(size < memory)
                available.setText("It can be displayed on the image view.");
            else if(size > memory)
                available.setText("It cannot be displayed on the image view without compressing.");

        }
    }

    public static boolean externalMemoryAvailable() {
        return android.os.Environment.getExternalStorageState().equals(
                android.os.Environment.MEDIA_MOUNTED);
    }

    public static String getAvailableExternalMemorySize() {
        if (externalMemoryAvailable()) {
            File path = Environment.getExternalStorageDirectory();
            StatFs stat = new StatFs(path.getPath());
            long blockSize = stat.getBlockSizeLong();
            long availableBlocks = stat.getAvailableBlocksLong();
            return String.valueOf(((availableBlocks * blockSize)/(1024*1024.0)));
        } else {
            return ERROR;
        }
    }
}

ImageData class:

package com.example.test;

import android.graphics.BitmapFactory;
import androidx.annotation.NonNull;
import java.io.File;

public class ImageData {

    private transient File file;

    public ImageData(@NonNull File file) {
        this.file = file;
        String fileName = file.getName();
    }

    public int[] getMeasure() {
        BitmapFactory.Options options = new BitmapFactory.Options();
        options.inJustDecodeBounds = true;
        BitmapFactory.decodeFile(file.getAbsolutePath(), options);
        int width = options.outWidth;
        int height = options.outHeight;

        return new int[] {width, height};
    }

}

Спасибо.

ADD:

  • Когда я пытаюсь получить ширину и высоту, он всегда возвращает 0.

.

BitmapFactory.Options options = new BitmapFactory.Options();
        options.inJustDecodeBounds = true;
        BitmapFactory.decodeResource(Resources.getSystem(), R.raw.disco_light);
        int width = options.outWidth;
        int height = options.outHeight;
  • А для памяти, должно ли оно приниматься какое-либо значение по умолчанию (размер изображения проверяется с помощью доступной памяти.) Для теста?
...