Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
signalapp
GitHub Repository: signalapp/Signal-iOS
Path: blob/main/SignalServiceKit/Messages/Attachments/V2/AudioWaveform/AudioWaveformSamplerTest.swift
1 views
//
// Copyright 2024 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
//

import Foundation
import XCTest

@testable import SignalServiceKit

final class AudioWaveformSamplerTest: XCTestCase {
    func testCorrectness() {
        let sampler = AudioWaveformSampler(inputCount: 8, outputCount: 3)
        sampler.update([4_000, 8_000, 12_000, 16_000])
        sampler.update([20_000, 24_000, 28_000, 32_000])
        let result = sampler.finalize()
        XCTAssertEqual(result.count, 3)
        XCTAssertEqual(result[0], -15.257, accuracy: 0.01)
        XCTAssertEqual(result[1], -6.413, accuracy: 0.01)
        XCTAssertEqual(result[2], -1.425, accuracy: 0.01)
    }

    func testOverflow() {
        do {
            let sampler = AudioWaveformSampler(inputCount: 11, outputCount: 10)
            sampler.update([32_767] + Array(repeating: 0, count: 9) + [32_767])
            let result = sampler.finalize()
            XCTAssertEqual(result.count, 10)
            XCTAssertEqual(result.first!, 0, accuracy: 0.01)
            XCTAssertEqual(result.last!, -25, accuracy: 0.01)
        }
        do {
            let sampler = AudioWaveformSampler(inputCount: 19, outputCount: 10)
            sampler.update([32_767] + Array(repeating: 0, count: 17) + [32_767])
            let result = sampler.finalize()
            XCTAssertEqual(result.count, 10)
            XCTAssertEqual(result.first!, 0, accuracy: 0.01)
            XCTAssertEqual(result.last!, -25, accuracy: 0.01)
        }
    }

    func testTooFewSamples() {
        let sampler = AudioWaveformSampler(inputCount: 5, outputCount: 10)
        sampler.update(Array(repeating: 0, count: 5))
        XCTAssertEqual(sampler.finalize().count, 5)
    }

    func testEmpty() {
        let sampler = AudioWaveformSampler(inputCount: 5, outputCount: 10)
        sampler.update([])
        XCTAssertEqual(sampler.finalize().count, 0)
    }
}

private extension AudioWaveformSampler {
    func update(_ samples: [Int16]) {
        samples.withUnsafeBufferPointer(self.update)
    }
}