import RNTest from './react-native-testkit/' import React from 'react' import RNFetchBlob from 'react-native-fetch-blob' import Timer from 'react-timer-mixin' import { StyleSheet, Text, View, ScrollView, CameraRoll, Platform, Dimensions, Image, } from 'react-native'; const fs = RNFetchBlob.fs const { Assert, Comparer, Info, prop } = RNTest const describe = RNTest.config({ group : '0.7.0', run : true, expand : false, timeout : 300000000, }) const { TEST_SERVER_URL, TEST_SERVER_URL_SSL, DROPBOX_TOKEN, styles } = prop() const dirs = RNFetchBlob.fs.dirs let prefix = ((Platform.OS === 'android') ? 'file://' : '') let bigfile = null describe('Upload and download large file', (report, done) => { let filename = Platform.OS+'-0.7.0-22mb-dummy-' + Date.now() let begin = -1 let begin2 = -1 let deb = Date.now() RNFetchBlob.config({ fileCache : true }) .fetch('GET', `${TEST_SERVER_URL}/public/1mb-dummy`) .progress((now, total) => { if(begin === -1) begin = Date.now() if(Date.now() - deb < 1000) return deb = Date.now() report( {`download ${now} / ${total} bytes (${Math.floor(now / (Date.now() - begin))} kb/s) ${(100*now/total).toFixed(2)}%`} ) }) .then((res) => { bigfile = res.path() return fs.stat(bigfile) }) .then((stat) => { report( {JSON.stringify(stat)} ) done() }) }) describe('cancel task should work properly', (report, done) => { let filename = Platform.OS+'-0.7.0-cancel-test-22mb-dummy-' + Date.now() let bytesWitten = 0 let deb = Date.now() let begin = -1 let task = RNFetchBlob.fetch('POST', 'https://content.dropboxapi.com/2/files/upload', { Authorization : `Bearer ${DROPBOX_TOKEN}`, 'Dropbox-API-Arg': '{\"path\": \"/rn-upload/'+filename+'\",\"mode\": \"add\",\"autorename\": true,\"mute\": false}', 'Content-Type' : 'application/octet-stream', }, RNFetchBlob.wrap(bigfile)) task.uploadProgress((now, total) => { bytesWitten = now if(Date.now() - deb < 1000) return deb = Date.now() if(begin === -1) begin = Date.now() let speed = Math.floor(now / (Date.now() - begin)) report( {`upload ${now} / ${total} bytes (${speed} kb/s)`} {` ${Math.floor((total-now)/speed/1000)} seconds left`} ) }) let checkpoint1 = 0 Timer.setTimeout(() => { task.cancel() }, 5000) Timer.setTimeout(() => { checkpoint1 = bytesWitten }, 6000) Timer.setTimeout(() => { report() fs.unlink(bigfile).then(() => { done() }) }, 10000) task .then((res) => { report( ) }) .catch((resp) => { report() done() }) })