mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
Merge pull request #848 from grasdk/master
Unit test and bugfix for CreationDate (#8)
This commit is contained in:
commit
a8b35bb76e
@ -362,34 +362,27 @@ export class MetadataLoader {
|
|||||||
//Filesystem is the absolute last resort, and it's hard to write tests for, since file system dates are changed on e.g. git clone.
|
//Filesystem is the absolute last resort, and it's hard to write tests for, since file system dates are changed on e.g. git clone.
|
||||||
if (exif.exif.DateTimeOriginal) {
|
if (exif.exif.DateTimeOriginal) {
|
||||||
//DateTimeOriginal is when the camera shutter closed
|
//DateTimeOriginal is when the camera shutter closed
|
||||||
if (exif.exif.OffsetTimeOriginal) { //OffsetTimeOriginal is the corresponding offset
|
let offset = exif.exif.OffsetTimeOriginal; //OffsetTimeOriginal is the corresponding offset
|
||||||
metadata.creationDate = timestampToMS(exif.exif.DateTimeOriginal, exif.exif.OffsetTimeOriginal);
|
if (!offset) { //Find offset among other options if possible
|
||||||
metadata.creationDateOffset = exif.exif.OffsetTimeOriginal;
|
offset = exif.exif.OffsetTimeDigitized || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.exif.DateTimeOriginal, exif.exif.GPSTimeStamp, exif.gps);
|
||||||
} else {
|
|
||||||
const alt_offset = exif.exif.OffsetTimeDigitized || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.exif.DateTimeOriginal, exif.exif.GPSTimeStamp, exif.gps);
|
|
||||||
metadata.creationDate = timestampToMS(exif.exif.DateTimeOriginal, alt_offset);
|
|
||||||
metadata.creationDateOffset = alt_offset;
|
|
||||||
}
|
}
|
||||||
|
metadata.creationDate = timestampToMS(exif.exif.DateTimeOriginal, offset);
|
||||||
|
metadata.creationDateOffset = offset;
|
||||||
} else if (exif.exif.CreateDate) { //using else if here, because DateTimeOriginal has preceedence
|
} else if (exif.exif.CreateDate) { //using else if here, because DateTimeOriginal has preceedence
|
||||||
//Create is when the camera wrote the file (typically within the same ms as shutter close)
|
//Create is when the camera wrote the file (typically within the same ms as shutter close)
|
||||||
if (exif.exif.OffsetTimeDigitized) { //OffsetTimeDigitized is the corresponding offset
|
let offset = exif.exif.OffsetTimeDigitized; //OffsetTimeDigitized is the corresponding offset
|
||||||
metadata.creationDate = timestampToMS(exif.exif.CreateDate, exif.exif.OffsetTimeDigitized);
|
if (!offset) { //Find offset among other options if possible
|
||||||
metadata.creationDateOffset = exif.exif.OffsetTimeDigitized;
|
offset = exif.exif.OffsetTimeOriginal || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.exif.DateTimeOriginal, exif.exif.GPSTimeStamp, exif.gps);
|
||||||
} else {
|
|
||||||
const alt_offset = exif.exif.OffsetTimeOriginal || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.exif.DateTimeOriginal, exif.exif.GPSTimeStamp, exif.gps);
|
|
||||||
metadata.creationDate = timestampToMS(exif.exif.DateTimeOriginal, alt_offset);
|
|
||||||
metadata.creationDateOffset = alt_offset;
|
|
||||||
}
|
}
|
||||||
|
metadata.creationDate = timestampToMS(exif.exif.CreateDate, offset);
|
||||||
|
metadata.creationDateOffset = offset;
|
||||||
} else if (exif.ifd0?.ModifyDate) { //using else if here, because DateTimeOriginal and CreatDate have preceedence
|
} else if (exif.ifd0?.ModifyDate) { //using else if here, because DateTimeOriginal and CreatDate have preceedence
|
||||||
if (exif.exif.OffsetTime) {
|
let offset = exif.exif.OffsetTime; //exif.Offsettime is the offset corresponding to ifd0.ModifyDate
|
||||||
//exif.Offsettime is the offset corresponding to ifd0.ModifyDate
|
if (!offset) { //Find offset among other options if possible
|
||||||
metadata.creationDate = timestampToMS(exif.ifd0.ModifyDate, exif.exif?.OffsetTime);
|
offset = exif.exif.DateTimeOriginal || exif.exif.OffsetTimeDigitized || getTimeOffsetByGPSStamp(exif.ifd0.ModifyDate, exif.exif.GPSTimeStamp, exif.gps);
|
||||||
metadata.creationDateOffset = exif.exif?.OffsetTime
|
}
|
||||||
} else {
|
metadata.creationDate = timestampToMS(exif.ifd0.ModifyDate, offset);
|
||||||
const alt_offset = exif.exif.DateTimeOriginal || exif.exif.OffsetTimeDigitized || getTimeOffsetByGPSStamp(exif.ifd0.ModifyDate, exif.exif.GPSTimeStamp, exif.gps);
|
metadata.creationDateOffset = offset
|
||||||
metadata.creationDate = timestampToMS(exif.ifd0.ModifyDate, alt_offset);
|
|
||||||
metadata.creationDateOffset = alt_offset;
|
|
||||||
}
|
|
||||||
} else if (exif.ihdr && exif.ihdr["Creation Time"]) {// again else if (another fallback date if the good ones aren't there) {
|
} else if (exif.ihdr && exif.ihdr["Creation Time"]) {// again else if (another fallback date if the good ones aren't there) {
|
||||||
const any_offset = exif.exif.DateTimeOriginal || exif.exif.OffsetTimeDigitized || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.ifd0.ModifyDate, exif.exif.GPSTimeStamp, exif.gps);
|
const any_offset = exif.exif.DateTimeOriginal || exif.exif.OffsetTimeDigitized || exif.exif.OffsetTime || getTimeOffsetByGPSStamp(exif.ifd0.ModifyDate, exif.exif.GPSTimeStamp, exif.gps);
|
||||||
metadata.creationDate = timestampToMS(exif.ihdr["Creation Time"], any_offset);
|
metadata.creationDate = timestampToMS(exif.ihdr["Creation Time"], any_offset);
|
||||||
|
BIN
test/backend/assets/wild-1-small.jpg
Normal file
BIN
test/backend/assets/wild-1-small.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 58 KiB |
20
test/backend/assets/wild-1-small.json
Normal file
20
test/backend/assets/wild-1-small.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"size": {
|
||||||
|
"width": 306,
|
||||||
|
"height": 204
|
||||||
|
},
|
||||||
|
"creationDate": 1435910683000,
|
||||||
|
"fileSize": 59564,
|
||||||
|
"positionData": {
|
||||||
|
"country": "United States",
|
||||||
|
"state": "Arizona",
|
||||||
|
"city": "Williams"
|
||||||
|
},
|
||||||
|
"keywords": ["Akela the wolf", "Balu the bear", "Bearizona", "Hugin the raven", "USA", "USA Road trip"],
|
||||||
|
"cameraData": {
|
||||||
|
"make": "Canon",
|
||||||
|
"model": "Canon EOS 600D",
|
||||||
|
"lens": "EF-S15-85mm f/3.5-5.6 IS USM"
|
||||||
|
},
|
||||||
|
"creationDateOffset": "+02:00"
|
||||||
|
}
|
@ -24,7 +24,7 @@ describe('DiskMangerWorker', () => {
|
|||||||
ProjectPath.ImageFolder = path.join(__dirname, '/../../../assets');
|
ProjectPath.ImageFolder = path.join(__dirname, '/../../../assets');
|
||||||
const dir = await DiskManager.scanDirectory('/');
|
const dir = await DiskManager.scanDirectory('/');
|
||||||
// should match the number of media (photo/video) files in the assets folder
|
// should match the number of media (photo/video) files in the assets folder
|
||||||
expect(dir.media.length).to.be.equals(14);
|
expect(dir.media.length).to.be.equals(15);
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
||||||
const expected = require(path.join(__dirname, '/../../../assets/test image öüóőúéáű-.,.json'));
|
const expected = require(path.join(__dirname, '/../../../assets/test image öüóőúéáű-.,.json'));
|
||||||
const i = dir.media.findIndex(m => m.name === 'test image öüóőúéáű-.,.jpg');
|
const i = dir.media.findIndex(m => m.name === 'test image öüóőúéáű-.,.jpg');
|
||||||
|
@ -112,6 +112,11 @@ describe('MetadataLoader', () => {
|
|||||||
expect(Utils.clone(data)).to.be.deep.equal(expected);
|
expect(Utils.clone(data)).to.be.deep.equal(expected);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
it('should load wild-1-small image with CreateDate from 2015, but no DateTimeOriginal', async () => {
|
||||||
|
const data = await MetadataLoader.loadPhotoMetadata(path.join(__dirname, '/../../../assets/wild-1-small.jpg'));
|
||||||
|
const expected = require(path.join(__dirname, '/../../../assets/wild-1-small.json'));
|
||||||
|
expect(Utils.clone(data)).to.be.deep.equal(expected);
|
||||||
|
});
|
||||||
|
|
||||||
describe('should load jpg with edge case exif data', () => {
|
describe('should load jpg with edge case exif data', () => {
|
||||||
const root = path.join(__dirname, '/../../../assets/edge_case_exif_data');
|
const root = path.join(__dirname, '/../../../assets/edge_case_exif_data');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user