TestValidateVolumeCapabilityRequest.java

/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.hadoop.yarn.csi.adaptor;

import org.apache.hadoop.thirdparty.com.google.common.collect.ImmutableList;
import org.apache.hadoop.thirdparty.com.google.common.collect.ImmutableMap;
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest;
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest.VolumeCapability;
import org.apache.hadoop.yarn.api.protocolrecords.impl.pb.ValidateVolumeCapabilitiesRequestPBImpl;
import org.apache.hadoop.yarn.proto.CsiAdaptorProtos;
import org.apache.hadoop.yarn.proto.CsiAdaptorProtos.VolumeCapability.AccessMode;
import org.apache.hadoop.yarn.proto.CsiAdaptorProtos.VolumeCapability.VolumeType;
import org.apache.hadoop.yarn.proto.YarnProtos;
import org.junit.jupiter.api.Test;

import static org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest.AccessMode.MULTI_NODE_MULTI_WRITER;
import static org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest.VolumeType.FILE_SYSTEM;
import static org.junit.jupiter.api.Assertions.assertEquals;

/**
 * UT for message exchanges.
 */
public class TestValidateVolumeCapabilityRequest {

  @Test
  void testPBRecord() {
    CsiAdaptorProtos.VolumeCapability vcProto =
        CsiAdaptorProtos.VolumeCapability.newBuilder()
            .setAccessMode(AccessMode.MULTI_NODE_MULTI_WRITER)
            .setVolumeType(VolumeType.FILE_SYSTEM)
            .addMountFlags("flag0")
            .addMountFlags("flag1")
            .build();

    CsiAdaptorProtos.ValidateVolumeCapabilitiesRequest requestProto =
        CsiAdaptorProtos.ValidateVolumeCapabilitiesRequest.newBuilder()
            .setVolumeId("volume-id-0000001")
            .addVolumeCapabilities(vcProto)
            .addVolumeAttributes(YarnProtos.StringStringMapProto
                .newBuilder().setKey("attr0")
                .setValue("value0")
                .build())
            .addVolumeAttributes(YarnProtos.StringStringMapProto
                .newBuilder().setKey("attr1")
                .setValue("value1")
                .build())
            .build();

    ValidateVolumeCapabilitiesRequestPBImpl request =
        new ValidateVolumeCapabilitiesRequestPBImpl(requestProto);

    assertEquals("volume-id-0000001", request.getVolumeId());
    assertEquals(2, request.getVolumeAttributes().size());
    assertEquals("value0", request.getVolumeAttributes().get("attr0"));
    assertEquals("value1", request.getVolumeAttributes().get("attr1"));
    assertEquals(1, request.getVolumeCapabilities().size());
    VolumeCapability vc =
        request.getVolumeCapabilities().get(0);
    assertEquals(MULTI_NODE_MULTI_WRITER, vc.getAccessMode());
    assertEquals(FILE_SYSTEM, vc.getVolumeType());
    assertEquals(2, vc.getMountFlags().size());

    assertEquals(requestProto, request.getProto());
  }

  @Test
  void testNewInstance() {
    ValidateVolumeCapabilitiesRequest pbImpl =
        ValidateVolumeCapabilitiesRequestPBImpl
            .newInstance("volume-id-0000123",
                ImmutableList.of(
                    new VolumeCapability(
                        MULTI_NODE_MULTI_WRITER, FILE_SYSTEM,
                        ImmutableList.of("mountFlag1", "mountFlag2"))),
                ImmutableMap.of("k1", "v1", "k2", "v2"));

    assertEquals("volume-id-0000123", pbImpl.getVolumeId());
    assertEquals(1, pbImpl.getVolumeCapabilities().size());
    assertEquals(FILE_SYSTEM,
        pbImpl.getVolumeCapabilities().get(0).getVolumeType());
    assertEquals(MULTI_NODE_MULTI_WRITER,
        pbImpl.getVolumeCapabilities().get(0).getAccessMode());
    assertEquals(2, pbImpl.getVolumeAttributes().size());

    CsiAdaptorProtos.ValidateVolumeCapabilitiesRequest proto =
        ((ValidateVolumeCapabilitiesRequestPBImpl) pbImpl).getProto();
    assertEquals("volume-id-0000123", proto.getVolumeId());
    assertEquals(1, proto.getVolumeCapabilitiesCount());
    assertEquals(AccessMode.MULTI_NODE_MULTI_WRITER,
        proto.getVolumeCapabilities(0).getAccessMode());
    assertEquals(VolumeType.FILE_SYSTEM,
        proto.getVolumeCapabilities(0).getVolumeType());
    assertEquals(2, proto.getVolumeCapabilities(0)
        .getMountFlagsCount());
    assertEquals(2, proto.getVolumeCapabilities(0)
        .getMountFlagsList().size());
  }
}