Github user tzulitai commented on a diff in the pull request:

    https://github.com/apache/flink/pull/5230#discussion_r163938102
  
    --- Diff: 
flink-runtime/src/main/java/org/apache/flink/runtime/state/RegisteredBroadcastBackendStateMetaInfo.java
 ---
    @@ -0,0 +1,232 @@
    +/*
    + * 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.flink.runtime.state;
    +
    +import org.apache.flink.api.common.typeutils.TypeSerializer;
    +import org.apache.flink.api.common.typeutils.TypeSerializerConfigSnapshot;
    +import org.apache.flink.util.Preconditions;
    +
    +import java.util.Objects;
    +
    +public class RegisteredBroadcastBackendStateMetaInfo<K, V> {
    +
    +   /** The name of the state, as registered by the user. */
    +   private final String name;
    +
    +   /** The mode how elements in this state are assigned to tasks during 
restore. */
    +   private final OperatorStateHandle.Mode assignmentMode;
    +
    +   /** The type serializer for the keys in the map state. */
    +   private final TypeSerializer<K> keySerializer;
    +
    +   /** The type serializer for the values in the map state. */
    +   private final TypeSerializer<V> valueSerializer;
    +
    +   public RegisteredBroadcastBackendStateMetaInfo(
    +                   final String name,
    +                   final OperatorStateHandle.Mode assignmentMode,
    +                   final TypeSerializer<K> keySerializer,
    +                   final TypeSerializer<V> valueSerializer) {
    +
    +           Preconditions.checkArgument(assignmentMode != null && 
assignmentMode == OperatorStateHandle.Mode.UNIFORM_BROADCAST);
    +
    +           this.name = Preconditions.checkNotNull(name);
    +           this.assignmentMode = assignmentMode;
    +           this.keySerializer = Preconditions.checkNotNull(keySerializer);
    +           this.valueSerializer = 
Preconditions.checkNotNull(valueSerializer);
    +   }
    +
    +   public String getName() {
    +           return name;
    +   }
    +
    +   public TypeSerializer<K> getKeySerializer() {
    +           return keySerializer;
    +   }
    +
    +   public TypeSerializer<V> getValueSerializer() {
    +           return valueSerializer;
    +   }
    +
    +   public OperatorStateHandle.Mode getAssignmentMode() {
    +           return assignmentMode;
    +   }
    +
    +   public RegisteredBroadcastBackendStateMetaInfo.Snapshot<K, V> 
snapshot() {
    +           return new RegisteredBroadcastBackendStateMetaInfo.Snapshot<>(
    +                           name,
    +                           assignmentMode,
    +                           keySerializer.duplicate(),
    +                           valueSerializer.duplicate(),
    +                           keySerializer.snapshotConfiguration(),
    +                           valueSerializer.snapshotConfiguration());
    +   }
    +
    +   @Override
    +   public boolean equals(Object obj) {
    +           if (obj == this) {
    +                   return true;
    +           }
    +
    +           if (!(obj instanceof RegisteredBroadcastBackendStateMetaInfo)) {
    +                   return false;
    +           }
    +
    +           final RegisteredBroadcastBackendStateMetaInfo other =
    +                           (RegisteredBroadcastBackendStateMetaInfo) obj;
    +
    +           return Objects.equals(name, other.getName())
    +                           && Objects.equals(assignmentMode, 
other.getAssignmentMode())
    +                           && Objects.equals(keySerializer, 
other.getKeySerializer())
    +                           && Objects.equals(valueSerializer, 
other.getValueSerializer());
    +   }
    +
    +   @Override
    +   public int hashCode() {
    +           int result = name.hashCode();
    +           result = 31 * result + assignmentMode.hashCode();
    +           result = 31 * result + keySerializer.hashCode();
    +           result = 31 * result + valueSerializer.hashCode();
    +           return result;
    +   }
    +
    +   @Override
    +   public String toString() {
    +           return "RegisteredBroadcastBackendStateMetaInfo{" +
    +                           "name='" + name + '\'' +
    +                           ", keySerializer=" + keySerializer +
    +                           ", valueSerializer=" + valueSerializer +
    +                           ", assignmentMode=" + assignmentMode +
    +                           '}';
    +   }
    +
    +   /**
    +    * A consistent snapshot of a {@link 
RegisteredOperatorBackendStateMetaInfo}.
    +    */
    +   public static class Snapshot<K, V> {
    +
    +           private String name;
    +           private OperatorStateHandle.Mode assignmentMode;
    +           private TypeSerializer<K> keySerializer;
    +           private TypeSerializer<V> valueSerializer;
    +           private TypeSerializerConfigSnapshot 
keySerializerConfigSnapshot;
    +           private TypeSerializerConfigSnapshot 
valueSerializerConfigSnapshot;
    +
    +           /** Empty constructor used when restoring the state meta info 
snapshot. */
    +           Snapshot() {}
    +
    +           private Snapshot(
    +                           final String name,
    +                           final OperatorStateHandle.Mode assignmentMode,
    +                           final TypeSerializer<K> keySerializer,
    +                           final TypeSerializer<V> valueSerializer,
    +                           final TypeSerializerConfigSnapshot 
keySerializerConfigSnapshot,
    +                           final TypeSerializerConfigSnapshot 
valueSerializerConfigSnapshot) {
    +
    +                   this.name = Preconditions.checkNotNull(name);
    +                   this.assignmentMode = 
Preconditions.checkNotNull(assignmentMode);
    +                   this.keySerializer = 
Preconditions.checkNotNull(keySerializer);
    +                   this.valueSerializer = 
Preconditions.checkNotNull(valueSerializer);
    +                   this.keySerializerConfigSnapshot = 
Preconditions.checkNotNull(keySerializerConfigSnapshot);
    +                   this.valueSerializerConfigSnapshot = 
Preconditions.checkNotNull(valueSerializerConfigSnapshot);
    +           }
    +
    +           public String getName() {
    +                   return name;
    +           }
    +
    +           void setName(String name) {
    +                   this.name = name;
    +           }
    +
    +           public OperatorStateHandle.Mode getAssignmentMode() {
    +                   return assignmentMode;
    +           }
    +
    +           void setAssignmentMode(OperatorStateHandle.Mode mode) {
    +                   this.assignmentMode = mode;
    +           }
    +
    +           public TypeSerializer<K> getKeySerializer() {
    +                   return keySerializer;
    +           }
    +
    +           void setKeySerializer(TypeSerializer<K> serializer) {
    +                   this.keySerializer = serializer;
    +           }
    +
    +           public TypeSerializer<V> getValueSerializer() {
    +                   return valueSerializer;
    +           }
    +
    +           void setValueSerializer(TypeSerializer<V> serializer) {
    +                   this.valueSerializer = serializer;
    +           }
    +
    +           public TypeSerializerConfigSnapshot 
getKeySerializerConfigSnapshot() {
    +                   return keySerializerConfigSnapshot;
    +           }
    +
    +           void 
setKeySerializerConfigSnapshot(TypeSerializerConfigSnapshot configSnapshot) {
    +                   this.keySerializerConfigSnapshot = configSnapshot;
    +           }
    +
    +           public TypeSerializerConfigSnapshot 
getValueSerializerConfigSnapshot() {
    +                   return valueSerializerConfigSnapshot;
    +           }
    +
    +           void 
setValueSerializerConfigSnapshot(TypeSerializerConfigSnapshot configSnapshot) {
    +                   this.valueSerializerConfigSnapshot = configSnapshot;
    +           }
    +
    +           @Override
    +           public boolean equals(Object obj) {
    +                   if (obj == this) {
    +                           return true;
    +                   }
    +
    +                   if (!(obj instanceof 
RegisteredBroadcastBackendStateMetaInfo.Snapshot)) {
    +                           return false;
    +                   }
    +
    +                   RegisteredBroadcastBackendStateMetaInfo.Snapshot 
snapshot =
    +                                   
(RegisteredBroadcastBackendStateMetaInfo.Snapshot) obj;
    +
    +                   // need to check for nulls because serializer and 
config snapshots may be null on restore
    --- End diff --
    
    I don't think the serializer and configs will be null in this case ...
    
    It _used_ to maybe be null in the past because previous versions did not 
have the config written.
    For adding broadcast state now, we should be able to ensure that there is 
always a restored config, and for unloadable serializers, it should be replaced 
with a `UnloadableDummyTypeSerializer`.


---

Reply via email to